日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學(xué)無先后,達(dá)者為師

網(wǎng)站首頁 編程語言 正文

箭頭函數(shù)中this與call()方法的關(guān)系

作者:GjenFly 更新時(shí)間: 2022-11-29 編程語言

今天學(xué)習(xí)到this指向內(nèi)容,它與call、apply和bind的關(guān)系,其中知識(shí)點(diǎn)有這么一句話:在箭頭函數(shù)中,this由詞法/靜態(tài)作用域設(shè)置(set lexically)。它被設(shè)置為包含它的execution context的this,并且不再被調(diào)用方式影響(call/apply/bind)。
最開始我還沒了解到具體的操作是怎么樣的,然后知道做了一個(gè)實(shí)驗(yàn)才明白其中的道理。
我是寫了這么一個(gè)代碼

var foo = () => this

var obj = {
  a: 'aaa',
  b: 'bbb'
}

console.log(foo.call(obj))

最開始我對(duì)這個(gè)程序的預(yù)想的效果是,定義一個(gè)foo的箭頭函數(shù)體使里面this指向全局對(duì)象,然后定義一個(gè)obj對(duì)象并在內(nèi)寫入內(nèi)容,最后log打印使用call()方法是this指向obj里面的內(nèi)容
可是調(diào)試出來的結(jié)果卻是this指向的依舊是全局對(duì)象,反復(fù)修改發(fā)現(xiàn)還是做不到預(yù)想效果,結(jié)果才回想起開頭的那句話。由于箭頭函數(shù)中的this是被靜態(tài)作用域設(shè)置,即函數(shù)被定義的時(shí)候就決定了一切,所以呢,就算怎么改變this的指向,它還是會(huì)指向原來的對(duì)象,即全局對(duì)象。這樣我才明白為什么我一直做不到預(yù)期的效果了。同樣,除了call()方法外,apply()和bind()方法也同樣改變不了this原本的指向?qū)ο蟆?/p>

原文鏈接:https://blog.csdn.net/GjenFly/article/details/104315773

欄目分類
最近更新