這篇文章運(yùn)用了實例代碼展示javascript中處理this指向的方法,代碼非常詳細(xì),感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。
目前創(chuàng)新互聯(lián)已為上千家的企業(yè)提供了網(wǎng)站建設(shè)、域名、雅安服務(wù)器托管、綿陽服務(wù)器托管、企業(yè)網(wǎng)站設(shè)計、通州網(wǎng)站維護(hù)等服務(wù),公司將堅持客戶導(dǎo)向、應(yīng)用為本的策略,正道將秉承"和諧、參與、激情"的文化,與客戶和合作伙伴齊心協(xié)力一起成長,共同發(fā)展。
例如,咱們可以在類數(shù)組對象上使用數(shù)組方法:
const reduce = Array.prototype.reduce; function sumArgs() { return reduce.call(arguments, (sum, value) => { return sum += value; }); } sumArgs(1, 2, 3); // => 6
另一方面,this
很難把握。
咱們經(jīng)常會發(fā)現(xiàn)自己用的 this
指向不正確。下面的教你如何簡單地將 this
綁定到所需的值。
在開始之前,我需要一個輔助函數(shù)execute(func)
,它僅執(zhí)行作為參數(shù)提供的函數(shù)。
function execute(func) { return func(); } execute(function() { return 10 }); // => 10
現(xiàn)在,繼續(xù)理解圍繞this
錯誤的本質(zhì):方法分離。
1.方法分離問題
假設(shè)有一個類Person
包含字段firstName
和lastName
。此外,它還有一個方法getFullName()
,該方法返回此人的全名。如下所示:
function Person(firstName, lastName) { this.firstName = firstName; this.lastName = lastName; this.getFullName = function() { this === agent; // => true return `${this.firstName} ${this.lastName}`; } } const agent = new Person('前端', '小智'); agent.getFullName(); // => '前端 小智'
可以看到Person
函數(shù)作為構(gòu)造函數(shù)被調(diào)用:new Person('前端', '小智')
。函數(shù)內(nèi)部的 this
表示新創(chuàng)建的實例。
getfullname()
返回此人的全名:'前端 小智'
。正如預(yù)期的那樣,getFullName()
方法內(nèi)的 this
等于agent
。
如果輔助函數(shù)執(zhí)行agent.getFullName
方法會發(fā)生什么:
execute(agent.getFullName); // => 'undefined undefined'
執(zhí)行結(jié)果不正確:'undefined undefined'
,這是 this
指向不正確導(dǎo)致的問題。
現(xiàn)在在getFullName()
方法中,this
的值是全局對象(瀏覽器環(huán)境中的 window
)。this
等于 window
,${window.firstName} ${window.lastName}
執(zhí)行結(jié)果是 'undefined undefined'
。
發(fā)生這種情況是因為在調(diào)用execute(agent.getFullName)
時該方法與對象分離?;旧习l(fā)生的只是常規(guī)函數(shù)調(diào)用(不是方法調(diào)用):
execute(agent.getFullName); // => 'undefined undefined' // 等價于: const getFullNameSeparated = agent.getFullName; execute(getFullNameSeparated); // => 'undefined undefined'
這個就是所謂的方法從它的對象中分離出來,當(dāng)方法被分離,然后執(zhí)行時,this
與原始對象沒有連接。
為了確保方法內(nèi)部的this
指向正確的對象,必須這樣做
以屬性訪問器的形式執(zhí)行方法:agent.getFullName()
this
綁定到包含的對象(使用箭頭函數(shù)、.bind()
方法等)方法分離問題,以及由此導(dǎo)致this
指向不正確,一般會在下面的幾種情況中出現(xiàn):
回調(diào)
// `methodHandler()`中的`this`是全局對象 setTimeout(object.handlerMethod, 1000);
在設(shè)置事件處理程序時
// React: `methodHandler()`中的`this`是全局對象 <button onClick={object.handlerMethod}> Click me </button>
接著介紹一些有用的方法,即如果方法與對象分離,如何使this
指向所需的對象。
2. 關(guān)閉上下文
保持this
指向類實例的最簡單方法是使用一個額外的變量self
:
function Person(firstName, lastName) { this.firstName = firstName; this.lastName = lastName; const self = this; this.getFullName = function() { self === agent; // => true return `${self.firstName} ${self.lastName}`; } } const agent = new Person('前端', '小智'); agent.getFullName(); // => '前端 小智' execute(agent.getFullName); // => '前端 小智'
getFullName()
靜態(tài)地關(guān)閉self
變量,有效地對this
進(jìn)行手動綁定。
現(xiàn)在,當(dāng)調(diào)用execute(agent.getFullName)
時,一切工作正常,因為getFullName()
方法內(nèi) this
總是指向正確的值。
3.使用箭頭函數(shù)
有沒有辦法在沒有附加變量的情況下靜態(tài)綁定this
?是的,這正是箭頭函數(shù)的作用。
使用箭頭函數(shù)重構(gòu)Person
:
function Person(firstName, lastName) { this.firstName = firstName; this.lastName = lastName; this.getFullName = () => `${this.firstName} ${this.lastName}`; } const agent = new Person('前端', '小智'); agent.getFullName(); // => '前端 小智' execute(agent.getFullName); // => '前端 小智'
箭頭函數(shù)以詞法方式綁定this
。簡單來說,它使用來自其定義的外部函數(shù)this
的值。
建議在需要使用外部函數(shù)上下文的所有情況下都使用箭頭函數(shù)。
4. 綁定上下文
現(xiàn)在讓咱們更進(jìn)一步,使用ES6中的類重構(gòu)Person
。
class Person { constructor(firstName, lastName) { this.firstName = firstName; this.lastName = lastName; } getFullName() { return `${this.firstName} ${this.lastName}`; } } const agent = new Person('前端', '小智'); agent.getFullName(); // => '前端 小智' execute(agent.getFullName); // => 'undefined undefined'
不幸的是,即使使用新的類語法,execute(agent.getFullName)
仍然返回“undefined undefined”
。
在類的情況下,使用附加的變量self
或箭頭函數(shù)來修復(fù)this
的指向是行不通的。
但是有一個涉及bind()
方法的技巧,它將方法的上下文綁定到構(gòu)造函數(shù)中:
class Person { constructor(firstName, lastName) { this.firstName = firstName; this.lastName = lastName; this.getFullName = this.getFullName.bind(this); } getFullName() { return `${this.firstName} ${this.lastName}`; } } const agent = new Person('前端', '小智'); agent.getFullName(); // => '前端 小智' execute(agent.getFullName); // => '前端 小智'
構(gòu)造函數(shù)中的this.getFullName = this.getFullName.bind(this)
將方法getFullName()
綁定到類實例。
execute(agent.getFullName)
按預(yù)期工作,返回'前端 小智'
。
5. 胖箭頭方法
bind
方式有點(diǎn)太過冗長,咱們可以使用胖箭頭的方式:
class Person { constructor(firstName, lastName) { this.firstName = firstName; this.lastName = lastName; } getFullName = () => { return `${this.firstName} ${this.lastName}`; } } const agent = new Person('前端', '小智'); agent.getFullName(); // => '前端 小智' execute(agent.getFullName); // => '前端 小智'
胖箭頭方法getFullName =() =>{…}
綁定到類實例,即使將方法與其對象分離。
這種方法是在類中綁定this
的最有效和最簡潔的方法。
6. 總結(jié)
與對象分離的方法會產(chǎn)生 this 指向不正確問題。靜態(tài)地綁定this
,可以手動使用一個附加變量self
來保存正確的上下文對象。然而,更好的替代方法是使用箭頭函數(shù),其本質(zhì)上是為了在詞法上綁定this
。
在類中,可以使用bind()
方法手動綁定構(gòu)造函數(shù)中的類方法。當(dāng)然如果你不用使用 bind
這種冗長方式,也可以使用簡潔方便的胖箭頭表示方法。
以上就是javascript中處理this指向的方法,詳細(xì)使用情況還需要大家自己親自動手使用過才能領(lǐng)會。如果想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!
分享題目:javascript中處理this指向的方法
轉(zhuǎn)載來源:http://m.rwnh.cn/article48/jepjep.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供外貿(mào)建站、網(wǎng)站導(dǎo)航、微信公眾號、建站公司、營銷型網(wǎng)站建設(shè)、App設(shè)計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)