JS中this指向

(1)事件調(diào)用環(huán)境:誰觸發(fā)事件,函數(shù)里面的this指向就是誰(某個(gè)DOM)。

(2)node全局環(huán)境:this指向module.exports

(3)瀏覽器全局環(huán)境:this指向window

(4)函數(shù)內(nèi)部:

(4.1)函數(shù)自己調(diào)用(不是對象調(diào)用)嚴(yán)格模式下:undefined,非嚴(yán)格模式下 :this指向window

(4.2)函數(shù)被對象調(diào)用,this指向最終調(diào)用函數(shù)的對象。注意是調(diào)用時(shí)的,不是定義時(shí)的。

(4.3)構(gòu)造函數(shù)中沒有return語句,構(gòu)造函數(shù)中的this指向的是實(shí)例對象

構(gòu)造函數(shù)有return返回值,返回值類型為基本類型,構(gòu)造函數(shù)中的this指向的是實(shí)例對象

構(gòu)造函數(shù)有return返回值,返回值類型為引用類型,構(gòu)造函數(shù)中的this指向返回值的對象

(5)箭頭函數(shù):箭頭函數(shù)的上一層作用域的this

箭頭函數(shù)本身是沒有this和arguments的,在箭頭函數(shù)中引用的this實(shí)際調(diào)用的是定義這個(gè)箭頭函數(shù)的上一層作用域的this。這里強(qiáng)調(diào)一下是上一層作用域,因?yàn)閷ο笫遣荒苄纬瑟?dú)立的作用域的。

修改this指向三種方法:

(1) call(this,a,b,c)

(2) apply(this,[a,b,c])

(3) bind(this,a,b,c)()

在定義箭頭函數(shù)時(shí)已決定箭頭函數(shù)中this指向,定義后想再通過call來修改函數(shù)中的this指向是做不到的,普通函數(shù)可以做到用call修改this指向。

腦圖總結(jié):


this指向

附一道經(jīng)典面試題:

經(jīng)典題目
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

友情鏈接更多精彩內(nèi)容