關(guān)于ES6箭頭函數(shù)中的this問(wèn)題
簡(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)文章
小程序?qū)崿F(xiàn)抽獎(jiǎng)動(dòng)畫(huà)
這篇文章主要為大家詳細(xì)介紹了小程序?qū)崿F(xiàn)抽獎(jiǎng)動(dòng)畫(huà),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12JS拖拽的進(jìn)一步練習(xí),移動(dòng)與拉伸實(shí)現(xiàn)代碼
這次增加了一些相關(guān)的功能,增加四個(gè)角的拉伸改變寬度,主要還是用到一些簡(jiǎn)單的坐標(biāo)位置計(jì)算,沒(méi)有什么技術(shù)難度,熟練了一下自己對(duì)拖拽的運(yùn)用2012-05-05JS實(shí)現(xiàn)的驗(yàn)證身份證及獲取地區(qū)功能示例
這篇文章主要介紹了JS實(shí)現(xiàn)的驗(yàn)證身份證及獲取地區(qū)功能,結(jié)合實(shí)例形式分析了JS字符串、數(shù)組及正則操作相關(guān)技巧,需要的朋友可以參考下2017-01-01JavaScript基礎(chǔ)入門(mén)之錯(cuò)誤捕獲機(jī)制
初級(jí)開(kāi)發(fā)人員往往很少使用js的拋出和捕獲異常,但拋出和捕獲異常往往是非常必要的,這篇文章主要給大家介紹了關(guān)于JavaScript基礎(chǔ)入門(mén)之錯(cuò)誤捕獲機(jī)制的相關(guān)資料,需要的朋友可以參考下2021-08-08js removeChild 障眼法 可能出現(xiàn)的錯(cuò)誤
js removeChild 障眼法之可能出現(xiàn)的錯(cuò)誤,大家看下代碼就知道了。2009-10-10BootStrap Validator使用注意事項(xiàng)(必看篇)
針對(duì)bootstrap2和bootstrap3有不同的版本,在使用bootstrap validator時(shí)需要了解其注意事項(xiàng),下面小編把我遇到的注意事項(xiàng)分享給大家,供大家參考2016-09-09kindeditor編輯器點(diǎn)中圖片滾動(dòng)條往上頂?shù)腷ug
這篇文章主要介紹了kindeditor編輯器點(diǎn)中圖片滾動(dòng)條往上頂?shù)腷ug的相關(guān)資料,需要的朋友可以參考下2015-07-07