摘要:指定為原始值數(shù)字,字符串,布爾值會指向該原始值的自動包裝對象這一點感謝評論區(qū)的讀者補充。
前言
(幾天之前寫了源碼分析之后,感覺太疲憊了,寫一些相對輕巧的內(nèi)容調(diào)劑一下,希望喜歡的同學(xué)可以點個贊和收藏~)
進入正題,this對象在js中是很常見,但是在這里也經(jīng)常會出錯,本文將對常見的this對象的情況做一些總結(jié)
this對象是在函數(shù)運行時,基于函數(shù)的執(zhí)行環(huán)境綁定的。
其實這句話的本質(zhì)就是,誰調(diào)用了函數(shù),this就指向誰
具體的來說,通常有以下幾種情況:
全局函數(shù)在全局環(huán)境中,this指向Window
//例子1 function A() { console.log(this) } A();//Window
上面的例子很簡單,函數(shù)A在全局環(huán)境中執(zhí)行,也就是全局對象Window調(diào)用了函數(shù)。此時this指向Window
對象方法作為對象方法調(diào)用時,this指向調(diào)用該方法的對象
//例子2 var b = { getThis:function(){ console.log(this) } } b.getThis()//b
到這里我們舉的例子都比較簡單易懂,接下來來一個有意思的:
//例子3 var c = { getFunc:function(){ return function(){ console.log(this) } } } var cFun = c.getFunc() cFun()//Window
這個例子和前一個例子不一樣,運行c.getFunc()時,首先返回的是一個匿名函數(shù),我們將這個函數(shù)賦值給cFun,接著在全局環(huán)境中調(diào)用了cFun(),所以此時this指向的還是Window。
如果我們一定要讓這里返回的是c對象呢?在開頭我們說過,this對象是在函數(shù)執(zhí)行時確定的,在例子3中,執(zhí)行c.getFunc()時,this對象指向的還是c,所以我們只要保持住這個this就好了,對上面的代碼稍微改動:
//例子4 var c = { getFunc:function(){ var that = this //在這里保留住this return function(){ console.log(that) } } } var cFun = c.getFunc() cFun()//c
這也就是我們經(jīng)??梢栽谝恍┐a中看到var self = this或者var that = this之類的原因了。
call和apply此時this對象通常指向函數(shù)中指定的this值(注意這里的通常2字,考試要考的)
call和apply算是老生常談,但還是稍微介紹下,怕新同學(xué)可能沒接觸過(其實是為了湊點字?jǐn)?shù)),拿call來說,語法是這樣的
fun.call(thisArg, arg1, arg2, ...)
這個方法怎么用呢,看下面的例子:
//例子5 var d = { getThis:function(){ console.log(this) } } var e = { name:"e"http://(給e寫個`name`屬性只是因為覺得孤零零的太難看了~~) } d.getThis.call(e)//e
在這里我們就可以看出call函數(shù)的意思了:指定一個對象o1去調(diào)用其他對象o2的方法,此時this對象指向o1
好了,那為什么前面我們說通常呢?因為,有2種例外的情況:
thisArg指定為null和undefined時,this指向window。
thisArg指定為原始值(數(shù)字,字符串,布爾值),this會指向該原始值的自動包裝對象(這一點感謝評論區(qū)的讀者補充)。請看:
//例子6 var d = { getThis:function(){ console.log(this) } } d.getThis.call(null)//Window d.getThis.call(undefined)//Window d.getThis.call(1) //Number d.getThis.call("hello") //String d.getThis.call(true) //Boolean番外:基本包裝類型
既然講到包裝類型,那這里順便補充介紹一下基本包裝類型:基本包裝類型(包括Boolean,String,Number)是一類特殊的引用類型,它們具有引用類型的基本特征,還具有對應(yīng)的基本類型的特殊行為,舉個例子:
//基本包裝類型 var str = "hello World"; var str2 = s1.substring(2);
首先,str是字符串,字符串是基本數(shù)據(jù)類型,但是在第二行代碼中,str.substring(2)調(diào)用了str的方法,我們知道,基本數(shù)據(jù)類型不是對象,本來是是不應(yīng)該有方法的,但是實際上我們知道string,number類型都有對應(yīng)的方法,因為從內(nèi)存中訪問str時,訪問進入了一種讀取模式,在后臺自動做了以下轉(zhuǎn)換:
創(chuàng)建一個String類型的實例
在實例上調(diào)用相應(yīng)方法
銷毀該實例
特點:自動創(chuàng)建的基本包裝類型的對象只存在于執(zhí)行代碼的瞬間,然后立即銷毀。
那么可以手動創(chuàng)建基本包裝類型嗎?當(dāng)然可以:
var str = new String("Hello")//注意這里是new一個實例,而不是用String類型轉(zhuǎn)換函數(shù) typeof(str)//object var str2 = String(222)//如果使用類型轉(zhuǎn)換函數(shù)得到的還是類型 ypeof(str2)//string
此時的str就是一個顯式創(chuàng)建的基本包裝類型對象,只是一般來說很少這樣去使用
箭頭函數(shù)es6中的箭頭函數(shù)現(xiàn)在也用的比較頻繁,但是有個需要注意的點是:
函數(shù)體內(nèi)的this對象,就是定義時所在的對象,而不是使用時所在的對象。
其實出現(xiàn)這種情況的根本原因是:箭頭函數(shù)沒有this對象,所以箭頭函數(shù)的this就是外層代碼的this
//例子7 var f = { getThis:()=>{ console.log(this) } } f.getThis()//Window
這個例子和前面例子2是基本一樣的,只是把普通函數(shù)改寫成箭頭函數(shù),但是此時的this對象已經(jīng)指向了外層的Window。
考慮到這一點可能不好理解,我們再看幾個例子:
//例子8 var g = { getThis:function(){ return function(){console.log(this)} } } var h = { getThis:function(){ return ()=> console.log(this) } } g.getThis()()//Window h.getThis()()//h
這個例子里,g的getThis寫法就和之前的例子3一樣,由于函數(shù)在全局環(huán)境中運行,所以此時this指向Window;h的getThis使用了箭頭函數(shù),所以this指向了外層代碼塊的this所以,此時this指向的是h。
總結(jié)小結(jié)一下,
一般情況下this對象指向調(diào)用函數(shù)的對象,全局環(huán)境中執(zhí)行函數(shù)this對象指向Window
在call和apply函數(shù)中this指向指定的對象,如果指定的對為undefined或者null,那么this對象指向Window
在箭頭函數(shù)中,this對象等同于外層代碼塊的this
然后依然是每次都一樣的結(jié)尾,如果內(nèi)容有錯誤的地方歡迎指出;如果對你有幫助,歡迎點贊和收藏,轉(zhuǎn)載請征得同意后著明出處,如果有問題也歡迎私信交流,主頁添加了郵箱地址~溜了
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/90657.html
摘要:什么是函數(shù)引用的原話函數(shù)是一組可以隨時隨地運行的語句。函數(shù)是由這樣的方式進行聲明的關(guān)鍵字函數(shù)名一組參數(shù),以及置于括號中的待執(zhí)行代碼。 什么是函數(shù)? 引用 W3School 的原話: 函數(shù)是一組可以隨時隨地運行的語句。 函數(shù)是 ECMAScript 的核心。 函數(shù)是由這樣的方式進行聲明的:關(guān)鍵字 function、函數(shù)名、一組參數(shù),以及置于括號中的待執(zhí)行代碼。 函數(shù)的基本語法是這樣的:...
摘要:預(yù)解析聲明告知瀏覽器在全局作用域中有一個變量名為的變量。執(zhí)行代碼的就是棧內(nèi)存,作用域也是棧內(nèi)存。關(guān)鍵字在中主要研究都是函數(shù)中的中的代表的是當(dāng)前行為執(zhí)行的主體方法,函數(shù),事件中的上下文代表的是當(dāng)前行為執(zhí)行的環(huán)境區(qū)域例如小明在沙縣小吃吃蛋炒飯。 基本認(rèn)識 數(shù)據(jù)類型 基本數(shù)據(jù)類型 string, number, null, boolean, undefined 引用數(shù)據(jù)類型 object: ...
摘要:執(zhí)行完成后會返回如下圖的結(jié)果,根據(jù)返回數(shù)據(jù)把源碼和存儲在的屬性上的回調(diào)函數(shù)中調(diào)用類生成,并根據(jù)生成依賴后回調(diào)方法返回類。 webpack設(shè)計模式 一切資源皆Module Module(模塊)是webpack的中的關(guān)鍵實體。Webpack 會從配置的 Entry 開始遞歸找出所有依賴的模塊. 通過Loaders(模塊轉(zhuǎn)換器),用于把模塊原內(nèi)容按照需求轉(zhuǎn)換成新模塊內(nèi)容. 事件驅(qū)動架構(gòu) we...
摘要:中有三種不同的對象,三種對象的屬性和行為和下方的類似構(gòu)造函數(shù)對象構(gòu)造函數(shù)為的類定義名稱,任何添加到這個構(gòu)造函數(shù)對象中的屬性都是類字段和類方法。 JavaScript中的Java式繼承 區(qū)別 Java類似的強類型面向?qū)ο笳Z言,類為 實例字段 他們是基于實例的屬性或變量,用以保存獨立對象的狀態(tài) 實例方法 他們是類的所有實例所共享的方法,由每個獨立的實例調(diào)用 類字段 這些屬性或者變量是屬于類...
摘要:當(dāng)我們不想再對象內(nèi)部間接包含引用函數(shù),而像在某個對象上強制調(diào)用函數(shù)。我們可以用中內(nèi)置的和的方法來實現(xiàn),這兩個方法的第一個參數(shù)是一個對象,是給準(zhǔn)備的,接著再調(diào)用函數(shù)時將其綁定到。 this是什么 在javascript中,每個執(zhí)行上下文可以抽象成一組對象showImg(https://segmentfault.com/img/bVuKR7); 而this是與執(zhí)行上下文相關(guān)的特殊對象,任何...
閱讀 2122·2023-04-26 00:41
閱讀 1155·2021-09-24 10:34
閱讀 3585·2021-09-23 11:21
閱讀 4116·2021-09-22 15:06
閱讀 1567·2019-08-30 15:55
閱讀 908·2019-08-30 15:54
閱讀 1836·2019-08-30 15:48
閱讀 561·2019-08-29 13:58