普通函數(shù)和箭頭函數(shù)的this指向

普通函數(shù)與箭頭函數(shù)

普通函數(shù)指的是用 function 定義的函數(shù):

var hello = function() {

????console.log("Hello, Fundebug!");

};

箭頭函數(shù)指的是用=>定義的函數(shù):

var hello = () => {

????console.log("Hello, Fundebug!");

};

箭頭函數(shù)與普通函數(shù)不只是寫法上的區(qū)別,它們還有一些微妙的不同點,其中一個不同點就是 this村象。箭頭函數(shù)沒有自己的 this 值肝劲,箭頭函數(shù)中所使用的 this 來自于函數(shù)作用域鏈宽堆。

this 到底是什么透揣?

JavaScript 是一門比較奇特的語言,它的 this 與其他語言不一樣焕妙,并且它的取值還取決于代碼是否為嚴(yán)格模式(“use strict”)以及函數(shù)中的 this 值取決于這個函數(shù)是怎樣被調(diào)用的拴事。this就是代碼執(zhí)行時當(dāng)前的context object沃斤。代碼沒有在任何函數(shù)中執(zhí)行,而是在全局作用域中執(zhí)行時刃宵,this 的值就是 global 對象衡瓶,對于瀏覽器來說,this 就是 window牲证。

當(dāng)函數(shù)作為對象的方法被調(diào)用時哮针,它的 this 值就是該對象:

var circle = {

????radius:10,

? ? getRadius() {

????????console.log(this.radius);

? ? }

};

circle.getRadius();????// 打印 10

當(dāng)我們需要在對象方法中嵌套一個內(nèi)層函數(shù)時,this的指向就會給我們帶來實際的困擾了,這時就需要使用一個臨時變量self去保存這個this:

var circle = {

????radius:10,

? ? outerDiameter() {

????????var self = this;

????????var innerDiameter = function() {

????????????console.log(2* self.radius);

????????????console.log(this === window);

? ? ? ? };

? ? ? ? innerDiameter();

? ? }

};

circle.outerDiameter();????// 分別打印20和true

outerDiameter 函數(shù)是 circle 對象的方法十厢,因此其 this 值就是 circle 對象等太。但內(nèi)層函數(shù)innerDiameter并不會繼承外層函數(shù) outerDiameter 的 this 值。因此outerDiameter 函數(shù)的 this 值就是 circle 對象蛮放,this.radius 等于 10缩抡。但是innerDiameter函數(shù)的this值不是circle對象。

因此包颁,如果我們直接在 innerDiameter 函數(shù)中使用 this 的話瞻想,就會問題了:

// 使用普通函數(shù)

var circle = {

????radius:10,

? ? outerDiameter() {

????????varinnerDiameter =function(){

????????????console.log(2*this.radius);

? ? ????};

? ? ????innerDiameter();

? ? }

};

circle.outerDiameter();????// 打印NaN

.bind(this)

我們也可以使用.bind(this)來綁定this:

var circle = {

????radius:10,

? ? outerDiameter() {

????????varinnerDiameter = function() {

????????????console.log(2*this.radius);

? ? ? ? };

????????innerDiameter = innerDiameter.bind(this);

? ? ? ? innerDiameter();

? ? }

};

circle.outerDiameter();????// 打印20

箭頭函數(shù)

箭頭函數(shù)的 this 取值,規(guī)則非常簡單娩嚼,因為 this 在箭頭函數(shù)中蘑险,可以看做一個普通變量。箭頭函數(shù)沒有自己的 this 值岳悟,箭頭函數(shù)中所使用的 this 都是來自函數(shù)作用域鏈佃迄,它的取值遵循普通普通變量一樣的規(guī)則,在函數(shù)作用域鏈中一層一層往上找贵少。

對于需要使用object.method()方式調(diào)用的函數(shù)呵俏,使用普通函數(shù)定義,不要使用箭頭函數(shù)春瞬。對象方法中所使用的 this 值有確定的含義柴信,指的就是 object 本身。其他情況下宽气,使用箭頭函數(shù)。

varcircle = {

????radius:10,

? ? outerDiameter() {

????????varinnerDiameter = () => {

????????????console.log(2*this.radius);

? ? ? ? };

? ? ? ? innerDiameter();

? ? }

};

circle.outerDiameter();????// 打印20

對于內(nèi)層函數(shù) innerDiameter潜沦,它本身并沒有 this 值萄涯,其使用的 this 來自作用域鏈,來自更高層函數(shù)的作用域唆鸡。innerDiameter 的外層函數(shù) outerDiameter 是普通函數(shù)涝影,它是有 this 值的,它的 this 值就是 circle 對象争占。因此燃逻,innerDiameter 函數(shù)中所使用的 this 來自 outerDiameter 函數(shù),其值為 circle 對象臂痕。



文章來源:https://blog.fundebug.com/2019/06/18/arrow-function-this/

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末伯襟,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子握童,更是在濱河造成了極大的恐慌姆怪,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,378評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異稽揭,居然都是意外死亡俺附,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,356評論 2 382
  • 文/潘曉璐 我一進店門溪掀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來事镣,“玉大人,你說我怎么就攤上這事揪胃÷耄” “怎么了?”我有些...
    開封第一講書人閱讀 152,702評論 0 342
  • 文/不壞的土叔 我叫張陵只嚣,是天一觀的道長沮稚。 經(jīng)常有香客問我,道長册舞,這世上最難降的妖魔是什么蕴掏? 我笑而不...
    開封第一講書人閱讀 55,259評論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮调鲸,結(jié)果婚禮上盛杰,老公的妹妹穿的比我還像新娘。我一直安慰自己藐石,他們只是感情好即供,可當(dāng)我...
    茶點故事閱讀 64,263評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著于微,像睡著了一般逗嫡。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上株依,一...
    開封第一講書人閱讀 49,036評論 1 285
  • 那天驱证,我揣著相機與錄音,去河邊找鬼恋腕。 笑死抹锄,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的荠藤。 我是一名探鬼主播伙单,決...
    沈念sama閱讀 38,349評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼哈肖!你這毒婦竟也來了吻育?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,979評論 0 259
  • 序言:老撾萬榮一對情侶失蹤牡彻,失蹤者是張志新(化名)和其女友劉穎扫沼,沒想到半個月后出爹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,469評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡缎除,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,938評論 2 323
  • 正文 我和宋清朗相戀三年严就,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片器罐。...
    茶點故事閱讀 38,059評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡梢为,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出轰坊,到底是詐尸還是另有隱情铸董,我是刑警寧澤,帶...
    沈念sama閱讀 33,703評論 4 323
  • 正文 年R本政府宣布肴沫,位于F島的核電站粟害,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏颤芬。R本人自食惡果不足惜悲幅,卻給世界環(huán)境...
    茶點故事閱讀 39,257評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望站蝠。 院中可真熱鬧汰具,春花似錦、人聲如沸菱魔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,262評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽澜倦。三九已至聚蝶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間肥隆,已是汗流浹背既荚。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留栋艳,地道東北人。 一個月前我還...
    沈念sama閱讀 45,501評論 2 354
  • 正文 我出身青樓句各,卻偏偏與公主長得像吸占,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子凿宾,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,792評論 2 345