」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 為什麼 JavaScript 中的「this」運算子不一致以及如何解決?

為什麼 JavaScript 中的「this」運算子不一致以及如何解決?

發佈於2024-11-08
瀏覽:350

Why is the \

在 Javascript 中,為什麼「this」運算子不一致?

在 JavaScript 中,「this」運算子表現出不同的行為,取決於呼叫上下文。這可能會導致混亂和意外結果,特別是在使用回調和物件時。

呼叫模式與「this」綁定

「this」運算子綁定到函數呼叫期間的物件或類別,此綁定由呼叫模式決定:

  • 方法: 當呼叫時物件的方法,「this」指物件本身。
  • 函數: 當作為獨立函數呼叫時,「this」會引用全域範圍(瀏覽器中的視窗物件)。
  • 建構子: 當使用「new」關鍵字呼叫時,會建立一個新對象,「this」指向該物件object.
  • Apply: “apply”方法允許明確設定“this”並在陣列中傳遞參數。

The回調難題

當方法的回呼作為函數呼叫時,就會出現問題。由於回呼不是作為方法呼叫的,因此「this」指的是全域範圍,而不是它原本打算的物件。

最佳實踐

維護的一個策略回調中「this」綁定的一致性是使用「var that = this;」圖案。這將對「this」(物件)的引用分配給一個新變數(that),然後可以在回調中使用該變數。

另一個推薦的方法是擁抱 JavaScript 的函數式程式設計方面並避免依賴類別和繼承模式。透過使用純函數和高階函數,您可以將邏輯與物件狀態分離,並實現更模組化且可預測的程式碼。

此外,考慮使用 JavaScript 框架,該框架提供了處理「this」綁定和物件的機制。以一致的方式進行面向程式設計。請記得仔細查看框架的文檔和怪癖,以避免意外行為。

版本聲明 本文轉載於:1729561575如有侵犯,請洽[email protected]刪除
最新教學 更多>
  • JavaScript中如何動態訪問全局變量?
    JavaScript中如何動態訪問全局變量?
    在JavaScript 一種方法是使用窗口對象存儲和檢索變量。通過引用全局範圍,可以使用其名稱動態訪問變量。 //一個腳本 var somevarname_10 = 20; //另一個腳本 window.all_vars = {}; window.all_vars ['somevarna...
    程式設計 發佈於2025-04-29
  • 如何使用Python的請求和假用戶代理繞過網站塊?
    如何使用Python的請求和假用戶代理繞過網站塊?
    如何使用Python的請求模擬瀏覽器行為,以及偽造的用戶代理提供了一個用戶 - 代理標頭一個有效方法是提供有效的用戶式header,以提供有效的用戶 - 設置,該標題可以通過browser和Acterner Systems the equestersystermery和操作系統。通過模仿像Chro...
    程式設計 發佈於2025-04-29
  • 在PHP中如何高效檢測空數組?
    在PHP中如何高效檢測空數組?
    在PHP 中檢查一個空數組可以通過各種方法在PHP中確定一個空數組。如果需要驗證任何數組元素的存在,則PHP的鬆散鍵入允許對數組本身進行直接評估:一種更嚴格的方法涉及使用count()函數: if(count(count($ playerList)=== 0){ //列表為空。 } 對...
    程式設計 發佈於2025-04-29
  • 如何使用Regex在PHP中有效地提取括號內的文本
    如何使用Regex在PHP中有效地提取括號內的文本
    php:在括號內提取文本在處理括號內的文本時,找到最有效的解決方案是必不可少的。一種方法是利用PHP的字符串操作函數,如下所示: 作為替代 $ text ='忽略除此之外的一切(text)'; preg_match('#((。 &&& [Regex使用模式來搜索特...
    程式設計 發佈於2025-04-29
  • VSCode在Go模板中顯示CSS驗證錯誤的原因
    VSCode在Go模板中顯示CSS驗證錯誤的原因
    在使用GO的html/template軟件包和編寫諸如mypage.tmpl之類的編寫模板時,對VSCODE中的CSS錯誤進行故障排除。 mypage.tmpl:可以觸發以下錯誤: 嘗試在樣式的html attribute。 settings。搜索“ html.validate.styles”。將其...
    程式設計 發佈於2025-04-29
  • HTML格式標籤
    HTML格式標籤
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    程式設計 發佈於2025-04-29
  • 如何從PHP中的數組中提取隨機元素?
    如何從PHP中的數組中提取隨機元素?
    從陣列中的隨機選擇,可以輕鬆從數組中獲取隨機項目。考慮以下數組:; 從此數組中檢索一個隨機項目,利用array_rand( array_rand()函數從數組返回一個隨機鍵。通過將$項目數組索引使用此鍵,我們可以從數組中訪問一個隨機元素。這種方法為選擇隨機項目提供了一種直接且可靠的方法。
    程式設計 發佈於2025-04-29
  • 如何使用Python有效地以相反順序讀取大型文件?
    如何使用Python有效地以相反順序讀取大型文件?
    在python 中,如果您使用一個大文件,並且需要從最後一行讀取其內容,則在第一行到第一行,Python的內置功能可能不合適。這是解決此任務的有效解決方案:反向行讀取器生成器 == ord('\ n'): 緩衝區=緩衝區[:-1] ...
    程式設計 發佈於2025-04-29
  • 如何檢查對像是否具有Python中的特定屬性?
    如何檢查對像是否具有Python中的特定屬性?
    方法來確定對象屬性存在尋求一種方法來驗證對像中特定屬性的存在。考慮以下示例,其中嘗試訪問不確定屬性會引起錯誤: >>> a = someClass() >>> A.property Trackback(最近的最新電話): 文件“ ”,第1行, AttributeError: SomeClass...
    程式設計 發佈於2025-04-29
  • 哪種方法更有效地用於點 - 填點檢測:射線跟踪或matplotlib \的路徑contains_points?
    哪種方法更有效地用於點 - 填點檢測:射線跟踪或matplotlib \的路徑contains_points?
    在Python Matplotlib's path.contains_points FunctionMatplotlib's path.contains_points function employs a path object to represent the polygon.它...
    程式設計 發佈於2025-04-29
  • Python實現鍵盤輸入超時功能的技巧
    Python實現鍵盤輸入超時功能的技巧
    等待超時輸入鍵盤輸入用戶輸入檢索過程可能會耗時,尤其是在使用大量數據時。為了防止過度等待,希望在輸入提示期間實現超時。 一個解決方案涉及利用選擇調用。此方法是簡潔且可移植的:導入sys,選擇 打印(“您有十秒鐘可以回答!”) #將`timeout'指定為10秒 i,o,e = select...
    程式設計 發佈於2025-04-29
  • 版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    版本5.6.5之前,使用current_timestamp與時間戳列的current_timestamp與時間戳列有什麼限制?
    在時間戳列上使用current_timestamp或MySQL版本中的current_timestamp或在5.6.5 此限制源於遺留實現的關注,這些限制需要對當前的_timestamp功能進行特定的實現。 創建表`foo`( `Productid` int(10)unsigned not ...
    程式設計 發佈於2025-04-29
  • 如何從2D數組中提取元素?使用另一數組的索引
    如何從2D數組中提取元素?使用另一數組的索引
    Using NumPy Array as Indices for the 2nd Dimension of Another ArrayTo extract specific elements from a 2D array based on indices provided by a second ...
    程式設計 發佈於2025-04-29
  • 您如何在Laravel Blade模板中定義變量?
    您如何在Laravel Blade模板中定義變量?
    在Laravel Blade模板中使用Elegance 在blade模板中如何分配變量對於存儲以後使用的數據至關重要。在使用“ {{}}”分配變量的同時,它可能並不總是最優雅的解決方案。 幸運的是,Blade通過@php Directive提供了更優雅的方法: $ old_section =...
    程式設計 發佈於2025-04-29
  • Python中嵌套函數與閉包的區別是什麼
    Python中嵌套函數與閉包的區別是什麼
    嵌套函數與python 在python中的嵌套函數不被考慮閉合,因為它們不符合以下要求:不訪問局部範圍scliables to incling scliables在封裝範圍外執行範圍的局部範圍。 make_printer(msg): DEF打印機(): 打印(味精) ...
    程式設計 發佈於2025-04-29

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

Copyright© 2022 湘ICP备2022001581号-3