成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

箭頭函數(shù)中this的指向問(wèn)題

DDreach / 2834人閱讀

摘要:箭頭函數(shù)中指向等箭頭函數(shù)箭頭函數(shù)的,總是指向定義時(shí)所在的對(duì)象,而不是運(yùn)行時(shí)所在的對(duì)象。關(guān)鍵字通常不能在箭頭函數(shù)中使用除非是嵌套在允許使用的函數(shù)內(nèi)。參考資料的博客可以說(shuō)很厲害了圖解指向什么阮一峰關(guān)于箭頭函數(shù)的討論

箭頭函數(shù)中this指向等

箭頭函數(shù) javascript this

“箭頭函數(shù)”的this,總是指向定義時(shí)所在的對(duì)象,而不是運(yùn)行時(shí)所在的對(duì)象。

箭頭函數(shù)位于foo函數(shù)內(nèi)部。只有foo函數(shù)運(yùn)行后(被調(diào)用后,內(nèi)部this確定),它才會(huì)按照定義生成,所以foo運(yùn)行時(shí)所在的對(duì)象,恰好是箭頭函數(shù)定義時(shí)所在的對(duì)象

function foo() {
  setTimeout( () => {
    console.log("id:", this.id);
  },100);
}

var id = 21; // 箭頭函數(shù)運(yùn)行時(shí)所在的環(huán)境

foo.call( { id: 42 } ); // 箭頭函數(shù)定義時(shí)所在的環(huán)境

// 結(jié)果是 id: 42
function foo() {
  return () => {
    return () => {
      return () => {
        console.log("id:", this.id);
      };
    };
  };
}

var f = foo.call({id: 1});

var t1 = f.call({id: 2})()();
var t2 = f().call({id: 3})();
var t3 = f()().call({id: 4});

// 結(jié)果是: 1,1,1
var obj = {
  field: "hello",
  getField: () => { 
      // 此時(shí)箭頭函數(shù)被定義,this指向obj的this,而obj的this是window,則此箭頭函數(shù)的this指向window
    console.log(this)
  },
}
obj.getField();

//window 

箭頭函數(shù)里不但沒(méi)有 this,也沒(méi)有 arguments, super ……

var arguments = 42;
var arr = () => arguments;

arr(); // 42

function foo() {
  var f = (i) => arguments[0]+i; 
  // foo函數(shù)的間接參數(shù)綁定
  return f(2);
}

foo(1); // 3
 var f = (i) => arguments; 
 f(1); // arguments is not defined

通過(guò) call 或 apply 調(diào)用: 由于 this 已經(jīng)在詞法層面完成了綁定,通過(guò) call() apply() 方法調(diào)用一個(gè)函數(shù)時(shí),只是傳入了參數(shù)而已,對(duì) this 并沒(méi)有什么影響

var adder = {
  base : 1,
    
  add : function(a) {
    var f = v => v + this.base;
    return f(a);
  },

  addThruCall: function(a) {
    var f = v => v + this.base;
    var b = {
      base : 2
    };
            
    return f.call(b, a);
  }
};

console.log(adder.add(1));         // 輸出 2
console.log(adder.addThruCall(1)); // 仍然輸出 2

箭頭函數(shù)不能用作構(gòu)造器,和 new一起用會(huì)拋出錯(cuò)誤。

var Foo = () => {};
var foo = new Foo(); // TypeError: Foo is not a constructor

箭頭函數(shù)沒(méi)有prototype屬性。

var Foo = () => {};
console.log(Foo.prototype); // undefined

yield 關(guān)鍵字通常不能在箭頭函數(shù)中使用(除非是嵌套在允許使用的函數(shù)內(nèi))。因此,箭頭函數(shù)不能用作生成器。

參考資料

MDN

zhengweikeng的博客

可以說(shuō)很厲害了,圖解javascript this指向什么?

阮一峰e(cuò)s6關(guān)于箭頭函數(shù) this 的討論

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/92579.html

相關(guān)文章

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

    摘要:對(duì)象的指向是可變的,但是在箭頭函數(shù)中,它是固定的。同樣的由于箭頭函數(shù)沒(méi)有自己的所以傳統(tǒng)的顯性綁定無(wú)效內(nèi)部的指向外部在的學(xué)習(xí)中,的指向問(wèn)題一直是個(gè)難點(diǎn),特別是在對(duì)象方法中使用時(shí),必須更加小心。由此箭頭函數(shù)在很大程度上減少了我們的困擾。 什么是箭頭函數(shù) 用法 ES6 允許使用箭頭(=>)定義函數(shù) 測(cè)試 var p1 = document.getElementById(test1)...

    LeviDing 評(píng)論0 收藏0
  • 論普通函數(shù)箭頭函數(shù)區(qū)別以及箭頭函數(shù)注意事項(xiàng)、不適用場(chǎng)景

    摘要:第二種情況是箭頭函數(shù)的如果指向普通函數(shù)它的繼承于該普通函數(shù)。箭頭函數(shù)的指向全局,使用會(huì)報(bào)未聲明的錯(cuò)誤。 showImg(https://segmentfault.com/img/remote/1460000018610072?w=600&h=400); 箭頭函數(shù)是ES6的API,相信很多人都知道,因?yàn)槠湔Z(yǔ)法上相對(duì)于普通函數(shù)更簡(jiǎn)潔,深受大家的喜愛(ài)。就是這種我們?nèi)粘i_(kāi)發(fā)中一直在使用的API...

    paulquei 評(píng)論0 收藏0
  • ES6箭頭函數(shù)this指向哪里?

    摘要:注意因?yàn)榧^函數(shù)內(nèi)部的是指向外層代碼塊的最近的,例中的函數(shù)的,所以我們可以通過(guò)改變外層代碼塊的的指向從而改變箭頭函數(shù)中的指向例中使用了函數(shù)的方法。 一、this關(guān)鍵字小測(cè)試 ES6箭頭函數(shù)體中的this指向哪里? 在回答這個(gè)問(wèn)題之前先來(lái)揣揣你對(duì)this關(guān)鍵字的了解程度:(讓我們回到ES6之前)題: var obj = { a: function() { cons...

    Half 評(píng)論0 收藏0
  • 輕松搞定javascriptthis指向

    摘要:調(diào)用在中,通過(guò)的形式調(diào)用一個(gè)構(gòu)造函數(shù),會(huì)創(chuàng)建這個(gè)構(gòu)造函數(shù)實(shí)例,而這個(gè)實(shí)例的指向創(chuàng)建的這個(gè)實(shí)例。如下例所示,在構(gòu)造函數(shù)內(nèi)部使用并沒(méi)有改變?nèi)肿兞康闹?。顯然,箭頭函數(shù)是不能用來(lái)做構(gòu)造函數(shù)。   關(guān)于javascript中this指向的問(wèn)題,現(xiàn)總結(jié)如下,如有不正確,歡迎指正。   javascript中,this的指向并不是在函數(shù)定義的時(shí)候確定的,而是在其被調(diào)用的時(shí)候確定的。也就是說(shuō),函數(shù)的...

    shinezejian 評(píng)論0 收藏0
  • JavaScript this 指向問(wèn)題深度解析

    摘要:而改變了這種狀態(tài),雖然定義的類(lèi)用運(yùn)算符得到的仍然是,但它不能像普通函數(shù)一樣直接調(diào)用同時(shí),中定義的方法函數(shù),也不能當(dāng)作構(gòu)造函數(shù)用來(lái)調(diào)用。而在中,用調(diào)用一個(gè)構(gòu)造函數(shù),會(huì)創(chuàng)建一個(gè)新對(duì)象,而其中的就指向這個(gè)新對(duì)象。 JavaScript 中的 this 指向問(wèn)題有很多博客在解釋?zhuān)匀挥泻芏嗳藛?wèn)。上周我們的開(kāi)發(fā)團(tuán)隊(duì)連續(xù)兩個(gè)人遇到相關(guān)問(wèn)題,所以我不得不將關(guān)于前端構(gòu)建技術(shù)的交流會(huì)延長(zhǎng)了半個(gè)時(shí)候討論 ...

    liuchengxu 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<