溫馨提示×

溫馨提示×

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

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

JavaScript中this指向的使用方法

發(fā)布時間:2020-06-19 11:59:54 來源:億速云 閱讀:154 作者:鴿子 欄目:web開發(fā)

沒有箭頭函數(shù)之前,我們說this就是函數(shù)運行時所在的環(huán)境對象,但是在箭頭函數(shù)中this就是定義時所在的對象,先說大家熟知的:函數(shù)運行時所在的環(huán)境對象。

1、作為函數(shù)調(diào)用,this指向全局對象

JavaScript中this指向的使用方法

2、作為對象的方法調(diào)用,該對象即為調(diào)用上下文,this指向該對象。

JavaScript中this指向的使用方法

3、作為構(gòu)造函數(shù)調(diào)用,構(gòu)造函數(shù)試圖初始化這個新創(chuàng)建的對象,并將這個對象作為其調(diào)用上下文,this 指向這個新創(chuàng)建的對象。

JavaScript中this指向的使用方法

4、通過函數(shù)的call/apply方法間接調(diào)用, call/apply方法的第一個參數(shù)是調(diào)用上下文,在函數(shù)體內(nèi),通過this獲得對它的引用。

JavaScript中this指向的使用方法

箭頭函數(shù)中this對象就是定義時所在的作用域,也就是說箭頭函數(shù)本身沒有this,內(nèi)部的this就是外層代碼塊作用域中的this。

5、獨立函數(shù)

JavaScript中this指向的使用方法

該箭頭函數(shù)在全局環(huán)境中定義,即this指向window

6、對象的方法

如上所示,foo在全局中定義,所以this指向window,那么如何使this指向obj?

根據(jù)上一篇介紹,當函數(shù)作為對象的方法調(diào)用時this指向該對象,可以這樣改寫:

JavaScript中this指向的使用方法

func在foo調(diào)用時定義,此時的foo所在作用域為obj,因此this指向obj

7、構(gòu)造函數(shù),因箭頭函數(shù)沒有this,固不能用作構(gòu)造函數(shù),否則會報錯

JavaScript中this指向的使用方法

8bind/call

JavaScript中this指向的使用方法

如上:func定義在全局,因此打印0,同對象方法,我們可以通過如下改寫,打印出1

JavaScript中this指向的使用方法

以上就是JS干貨分享—-this指向問題的詳細內(nèi)容,更多請關(guān)注億速云其它相關(guān)文章!

向AI問一下細節(jié)

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

AI