簡(jiǎn)要介紹:箭頭函數(shù)中的this,指向與一般function定義的函數(shù)不同,箭頭函數(shù)this的定義:箭頭函數(shù)中的this是在定義函數(shù)的時(shí)候綁定,而不是在執(zhí)行函數(shù)的時(shí)候綁定。
(1)一般函數(shù)this指向在執(zhí)行是綁定 當(dāng)運(yùn)行obj.say()時(shí)候,this指向的是obj這個(gè)對(duì)象。
var x=11; var obj={ x:22, say:function(){ console.log(this.x) } } obj.say(); //console.log
(2)所謂的定義時(shí)候綁定,就是this是繼承自父執(zhí)行上下文!!中的this,比如這里的箭頭函數(shù)中的this.x,箭頭函數(shù)本身與say平級(jí)以key:value的形式,也就是箭頭函數(shù)本身所在的對(duì)象為obj,而obj的父執(zhí)行上下文就是window,因此這里的this.x實(shí)際上表示的是window.x,因此輸出的是11。
var x=11; var obj={ x:22, say:()=>{ console.log(this.x); } } obj.say(); //
類(lèi)似的還有:
(3)
var a=11 function test1(){ this.a=22; let b=function(){ console.log(this.a); }; b(); } var x=new test1();
輸出11
箭頭函數(shù)情況:
var a=11; function test2(){ this.a=22; let b=()=>{console.log(this.a)} b(); } var x=new test2(); //
很奇怪對(duì)不對(duì),我是這樣理解的,ES6中定義的時(shí)候綁定this的具體含義,應(yīng)該繼承的是父執(zhí)行上下文里面的this,切忌是父執(zhí)行上下文!!!這樣就很多箭頭函數(shù)中的指向不明確就迎刃而解了。
注意:簡(jiǎn)單對(duì)象(非函數(shù))是沒(méi)有執(zhí)行上下文的!
深入理解箭頭函數(shù)中的this
箭頭函數(shù)中,this指向的固定化,并不是因?yàn)榧^函數(shù)內(nèi)部有綁定this的機(jī)制,實(shí)際原因是箭頭函數(shù)根本沒(méi)有自己的this,導(dǎo)致內(nèi)部的this就是外層代碼塊的this。正是因?yàn)樗鼪](méi)有this,所以也就不能用作構(gòu)造函數(shù)。
我們可以來(lái)模擬ES5中的箭頭函數(shù)轉(zhuǎn)化:
// ES6 function foo() { setTimeout(() => { console.log('id:', this.id); }, 100); } // ES5 function foo() { var _this = this; setTimeout(function () { console.log('id:', _this.id); }, 100); }
所以在定義對(duì)象的時(shí)候,定義對(duì)象屬性,里面的this指向的一般是全局,或者這個(gè)對(duì)象所在的那個(gè)環(huán)境中的this。
總結(jié)
以上所述是小編給大家介紹的ES6箭頭函數(shù)中的this,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
聲明:本網(wǎng)頁(yè)內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問(wèn)題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com