欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于ES6箭頭函數(shù)中的this問(wèn)題

 更新時(shí)間:2018年02月27日 08:37:13   作者:var_chx  
ES6中新增了箭頭函數(shù)這種語(yǔ)法,箭頭函數(shù)以其簡(jiǎn)潔性和方便獲取this的特性,接下來(lái)通過(guò)本文給大家分享ES6箭頭函數(shù)中的this,感興趣的朋友一起看看吧

簡(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輸出的是22

(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();
//輸出的值為11

類(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();
//輸出22

很奇怪對(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)站的支持!

相關(guān)文章

最新評(píng)論