」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 在 JavaScript 中使用 setTimeout 時如何保留「this」引用?

在 JavaScript 中使用 setTimeout 時如何保留「this」引用?

發佈於2024-12-22
瀏覽:113

How to Preserve the \

setTimeout 和JavaScript 中難以捉摸的「this」

使用setTimeout 函數時,開發者經常會遇到後續呼叫方法遺失的問題他們的預期上下文,導致看似未定義的方法。這通常是由於丟失“this”引用引起的。

問題:

考慮以下程式碼:

test.prototype.method = function() {
    //method2 returns image based on the id passed
    this.method2('useSomeElement').src = "http://www.some.url";
    timeDelay = window.setTimeout(this.method, 5000);
};

test.prototype.method2 = function(name) {
    for (var i = 0; i  1) {
            return document.images[i];
        }
    }
};

在初始頁面載入時,method2 函數如預期般運作。但是設定逾時後,後續呼叫method2會報錯,提示未定義。

解決方案:

核心問題在於setTimeout的處理方式這個關鍵字。使用 setTimeout(this.method, 5000) 設定逾時時,上下文會遺失,從而導致錯誤。

解決此問題的一個巧妙方法是使用 bind() 方法。透過在方法呼叫末尾附加“.bind(this)”,可以明確綁定上下文,確保即使在超時後也能保持正確的“this”引用。

改良的程式碼:

test.prototype.method = function() {
    //method2 returns image based on the id passed
    this.method2('useSomeElement').src = "http://www.some.url";
    timeDelay = window.setTimeout(this.method.bind(this), 5000);
    //                                       ^^^^^^^^^^^ <- fix context
};

透過此修改,「this」的上下文被正確綁定,允許 method2 在超時到期後繼續按預期運行。這種方法在保留正確的執行上下文方面既優雅又有效。

版本聲明 本文轉載於:1729735477如有侵犯,請洽[email protected]刪除
最新教學 更多>
  • 如何在Java字串中正確地將單反斜線替換為雙反斜線?
    如何在Java字串中正確地將單反斜線替換為雙反斜線?
    在字符串中用雙反斜杠替換單反斜杠當嘗試使用replaceAll將像“\something\”這樣的字串轉換為“\”時某事”,開發人員經常遇到錯誤。使用ReplaceAll("\", "\\")方法的常見方法會導致異常「java.util.regex.Patte...
    程式設計 發佈於2024-12-22
  • 儘管在 Eclipse 的查找和替換中工作,為什麼我的 Java Regex 電子郵件驗證失敗?
    儘管在 Eclipse 的查找和替換中工作,為什麼我的 Java Regex 電子郵件驗證失敗?
    Java 正規表示式電子郵件驗證出現問題在嘗試使用正規表示式驗證電子郵件地址時,Java 使用者遇到了以下問題:即使對於格式正確的電子郵件地址,驗證也會失敗。儘管事實上,當在 Eclipse 中的「尋找和取代」功能中使用正規表示式時,該正規表示式會符合電子郵件地址,但在與 Java 的 Patter...
    程式設計 發佈於2024-12-22
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-12-22
  • 為什麼在將 std::min/max 與 #define NOMINMAX 一起使用時會出現錯誤?
    為什麼在將 std::min/max 與 #define NOMINMAX 一起使用時會出現錯誤?
    使用std::min/max 和#define NOMINMAX在main.cpp 檔案的最近更新中,您引入了以下預處理器指令: #define NOMINMAX #include <Windows.h> #include <algorithm>此操作可讓您在程式碼中使用 s...
    程式設計 發佈於2024-12-22
  • JHat 如何協助識別和調試 Java 記憶體洩漏?
    JHat 如何協助識別和調試 Java 記憶體洩漏?
    使用JHat 識別Java 中的記憶體洩漏在Java 中查找記憶體洩漏可能具有挑戰性,但是JHat(JDK 中包含的一個工具)提供有關堆使用情況的寶貴見解。雖然 JHat 提供了堆分配的基本視圖,但要找出記憶體洩漏的根本原因可能很困難。本文提供了一種系統方法來識別大型物件樹並定位導致記憶體洩漏的潛在...
    程式設計 發佈於2024-12-22
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-12-22
  • 使用 Python 的「w+」檔案模式有什麼意義?
    使用 Python 的「w+」檔案模式有什麼意義?
    Python 文件模式的混亂"w 在Python 中,有許多文件模式允許您以不同的方式與文件交互'w '就是這樣一種模式,它引起了一些混亂,讓我們澄清一下它的用法:理解文件。模式開啟一個檔案以進行寫入和更新。 &&&]為了更清楚地了解不同的文件模式,這裡有一個表格概述了它們...
    程式設計 發佈於2024-12-22
  • Java 的內建功能如何可靠地驗證電子郵件地址?
    Java 的內建功能如何可靠地驗證電子郵件地址?
    探討 Java 中的電子郵件驗證方法電子郵件地址的有效性在各種應用中至關重要。雖然 Apache Commons Validator 一直是 Java 電子郵件驗證的熱門選擇,但開發人員經常尋求替代解決方案。本文深入研究了使用官方 Java 電子郵件包驗證電子郵件地址的綜合方法。 isValidEm...
    程式設計 發佈於2024-12-22
  • 掌握 JavaScript 中的對象
    掌握 JavaScript 中的對象
    JavaScript 中的对象 在 JavaScript 中,对象是键值对的集合,其中值可以是数据(属性)或函数(方法)。对象是 JavaScript 的基础,因为 JavaScript 中几乎所有内容都是对象,包括数组、函数,甚至其他对象。 1.创建对象 ...
    程式設計 發佈於2024-12-22
  • C++ 中與運算子 (&) 的使用方式有哪些不同?
    C++ 中與運算子 (&) 的使用方式有哪些不同?
    && 在 C 語言中如何運作 && 在 C 語言中如何運作 理解 & 運算子& C中的運算子有多種用途,包括:取得某個位址變數: &x 傳回變數 x 的記憶體位址。 透過引用傳遞參數: void foo(CDummy& x);透過引用將變數 x 傳遞給函數 foo,允許在 foo 內部所做的修改反映...
    程式設計 發佈於2024-12-22
  • 馬尼拉 DevFest 推動創新、包容性和負責任的人工智慧
    馬尼拉 DevFest 推動創新、包容性和負責任的人工智慧
    图片来自GDG Manila Facebook页面(https://m.facebook.com/story.php?story_fbid=pfbid02Xh4ED8NwUnfrh9wrDS2pJKhYbpya4QxCMFWcNCeKuCpg9LgkmQ96B85FUSqo5w7bl&id=6156...
    程式設計 發佈於2024-12-22
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-12-22
  • C++中靜態工廠方法和工廠類別如何選擇?
    C++中靜態工廠方法和工廠類別如何選擇?
    如何在C 中正確實現工廠方法模式工廠方法模式是一種設計模式,允許創建對象而無需指定對象的確切類別要創建的對象。當運行時確定要建立的物件的類別時,或者需要提供統一的介面來建立不同類型的物件時,通常會使用這種模式。 在 C 中,有以下幾種方式實現工廠方法模式。一種常見的方法是使用在要為其建立物件的類別中...
    程式設計 發佈於2024-12-22
  • Java 中的 HashMap 或 Hashtable:對於單執行緒應用程式來說,哪個更有效率?
    Java 中的 HashMap 或 Hashtable:對於單執行緒應用程式來說,哪個更有效率?
    Java 中的HashMap 與Hashtable:非線程應用程式的主要區別和效率HashMap 和Hashtable 是Java 中的基本資料結構,它們儲存鍵值對。了解它們的差異對於選擇最合適的選項至關重要。 主要差異:同步: Hashtable 是同步的,而 HashMap 是同步的不是。同步意...
    程式設計 發佈於2024-12-22
  • MySQL 能否處理遙遠過去的日期,例如 1200 年?
    MySQL 能否處理遙遠過去的日期,例如 1200 年?
    MySQL 對歷史日期的支援許多資料庫系統,包括 MySQL,在處理歷史日期時都有限制。本文探討了儲存和使用公曆之前的日期的限制和替代方案。 MySQL 可以處理像 1200 這樣的日期嗎? 從技術上講,MySQL 可以儲存日期早在 1000 年。然而,對於在此之前的日期,存在潛在的問題考量。 歷史...
    程式設計 發佈於2024-12-22

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3