溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

ES6箭頭函數(shù)中this問題的示例分析

發(fā)布時間:2021-08-02 14:18:01 來源:億速云 閱讀:114 作者:小新 欄目:web開發(fā)

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

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

(1)一般函數(shù)this指向在執(zhí)行是綁定  當(dāng)運(yùn)行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實(shí)際上表示的是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指向的固定化,并不是因?yàn)榧^函數(shù)內(nèi)部有綁定this的機(jī)制,實(shí)際原因是箭頭函數(shù)根本沒有自己的this,導(dǎo)致內(nèi)部的this就是外層代碼塊的this。正是因?yàn)樗鼪]有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)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI