(1)事件調(diào)用環(huán)境:誰(shuí)觸發(fā)事件骡送,函數(shù)里面的this指向就是誰(shuí)(某個(gè)DOM)。
(2)node全局環(huán)境:this指向module.exports
(3)瀏覽器全局環(huán)境:this指向window
(4)函數(shù)內(nèi)部:
(4.1)函數(shù)自己調(diào)用(不是對(duì)象調(diào)用)嚴(yán)格模式下:undefined隘蝎,非嚴(yán)格模式下 :this指向window
(4.2)函數(shù)被對(duì)象調(diào)用,this指向最終調(diào)用函數(shù)的對(duì)象愤估。注意是調(diào)用時(shí)的搂妻,不是定義時(shí)的。
(4.3)構(gòu)造函數(shù)中沒有return語(yǔ)句蠢古,構(gòu)造函數(shù)中的this指向的是實(shí)例對(duì)象
構(gòu)造函數(shù)有return返回值奴曙,返回值類型為基本類型,構(gòu)造函數(shù)中的this指向的是實(shí)例對(duì)象
構(gòu)造函數(shù)有return返回值草讶,返回值類型為引用類型洽糟,構(gòu)造函數(shù)中的this指向返回值的對(duì)象
(5)箭頭函數(shù):箭頭函數(shù)的上一層作用域的this
箭頭函數(shù)本身是沒有this和arguments的,在箭頭函數(shù)中引用的this實(shí)際調(diào)用的是定義這個(gè)箭頭函數(shù)的上一層作用域的this堕战。這里強(qiáng)調(diào)一下是上一層作用域坤溃,因?yàn)閷?duì)象是不能形成獨(dú)立的作用域的。
修改this指向三種方法:
(1) call(this,a,b,c)
(2) apply(this,[a,b,c])
(3) bind(this,a,b,c)()
在定義箭頭函數(shù)時(shí)已決定箭頭函數(shù)中this指向嘱丢,定義后想再通過(guò)call來(lái)修改函數(shù)中的this指向是做不到的薪介,普通函數(shù)可以做到用call修改this指向。
腦圖總結(jié):
附一道經(jīng)典面試題: