真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

ES6箭頭函數(shù)中this問題的示例分析-創(chuàng)新互聯(lián)

小編給大家分享一下ES6箭頭函數(shù)中this問題的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

創(chuàng)新互聯(lián)-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比德江網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式德江網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋德江地區(qū)。費用合理售后完善,十載實體公司更值得信賴。

簡要介紹:箭頭函數(shù)中的this,指向與一般function定義的函數(shù)不同,箭頭函數(shù)this的定義:箭頭函數(shù)中的this是在定義函數(shù)的時候綁定,而不是在執(zhí)行函數(shù)的時候綁定。

(1)一般函數(shù)this指向在執(zhí)行是綁定  當(dāng)運行obj.say()時候,this指向的是obj這個對象。

var x=11;
var obj={
 x:22,
 say:function(){
 console.log(this.x)
 }
}
obj.say();
//console.log輸出的是22

(2)所謂的定義時候綁定,就是this是繼承自父執(zhí)行上下文!!中的this,比如這里的箭頭函數(shù)中的this.x,箭頭函數(shù)本身與say平級以key:value的形式,也就是箭頭函數(shù)本身所在的對象為obj,而obj的父執(zhí)行上下文就是window,因此這里的this.x實際上表示的是window.x,因此輸出的是11。

var x=11;
var obj={
 x:22,
 say:()=>{
 console.log(this.x);
 }
}
obj.say();
//輸出的值為11

類似的還有:

(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

很奇怪對不對,我是這樣理解的,ES6中定義的時候綁定this的具體含義,應(yīng)該繼承的是父執(zhí)行上下文里面的this,切忌是父執(zhí)行上下文?。。∵@樣就很多箭頭函數(shù)中的指向不明確就迎刃而解了。

注意:簡單對象(非函數(shù))是沒有執(zhí)行上下文的!

深入理解箭頭函數(shù)中的this

箭頭函數(shù)中,this指向的固定化,并不是因為箭頭函數(shù)內(nèi)部有綁定this的機制,實際原因是箭頭函數(shù)根本沒有自己的this,導(dǎo)致內(nèi)部的this就是外層代碼塊的this。正是因為它沒有this,所以也就不能用作構(gòu)造函數(shù)。

我們可以來模擬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);
}

所以在定義對象的時候,定義對象屬性,里面的this指向的一般是全局,或者這個對象所在的那個環(huán)境中的this。

以上是“ES6箭頭函數(shù)中this問題的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


當(dāng)前標(biāo)題:ES6箭頭函數(shù)中this問題的示例分析-創(chuàng)新互聯(lián)
網(wǎng)址分享:http://weahome.cn/article/cocjsh.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部