首頁 > web前端 > js教程 > 如何在「setTimeout」回呼中維護正確的「this」上下文?

如何在「setTimeout」回呼中維護正確的「this」上下文?

Barbara Streisand
發布: 2024-12-10 12:05:14
原創
912 人瀏覽過

How to Maintain the Correct `this` Context in `setTimeout` Callbacks?

確保 setTimeout 回呼中正確的 this 上下文

當使用 setTimeout 安排回呼函數時,請確保該函數保留所需的上下文。但是,當 this 引用回呼中的全域物件時,就會出現問題。

在提供的範例中:

if (this.options.destroyOnHide) {
     setTimeout(function() { this.tip.destroy() }, 1000);
}
登入後複製

this 引用全域窗口,而不是預期物件。為了防止這種情況,有幾種方法:

  1. 儲存上下文:

在呼叫 setTimeout 之前儲存對目前上下文的參考。

var that = this;
if (this.options.destroyOnHide) {
     setTimeout(function(){ that.tip.destroy() }, 1000);
}
登入後複製
  1. 使用bind方法(ES5):

使用 bind 建立一個綁定到正確上下文的新函數。

if (this.options.destroyOnHide) {
     setTimeout(function() { this.tip.destroy() }.bind(this), 1000);
}
登入後複製
  1. 使用箭頭函數 (ES6 ):

箭頭函數自動從其詞法繼承 this值

if (this.options.destroyOnHide) {
     setTimeout(() => { this.tip.destroy() }, 1000);
}
登入後複製
  1. 將參數傳遞給回調(HTML5):

HTML5 的計時器允許將參數傳遞給回調。

if (this.options.destroyOnHide) {
     setTimeout(function(that){ that.tip.destroy() }, 1000, this);
}
登入後複製

請記住,this 的上下文可能會根據函數的呼叫方式而有所不同。為了確保所需的行為,請根據可用的語言功能考慮適當的方法。

以上是如何在「setTimeout」回呼中維護正確的「this」上下文?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板