JS 探索 this 指向問題

来源:https://www.cnblogs.com/aurora-power/archive/2022/11/04/16857309.html
-Advertisement-
Play Games

1. 撲朔迷離的 this 從錶面來看,this 總能通過各種變通的方式得到意想不到的結果 既然是“意想不到”,就說明對“各種變通的方式”不太瞭解 那麼我們來看看“各種變通的方式” 老早以前,this 指向它的調用者 1 <script> 2 // 通過 dom 調用 3 var _html = d ...


1. 撲朔迷離的 this

  1. 從錶面來看,this 總能通過各種變通的方式得到意想不到的結果

  2. 既然是“意想不到”,就說明對“各種變通的方式”不太瞭解

  3. 那麼我們來看看“各種變通的方式”

    1. 老早以前,this 指向它的調用者
       1 <script>
       2     // 通過 dom 調用
       3     var _html = document.documentElement;
       4     _html.onclick = function () {
       5         console.log("this === _html", this === _html); // true
       6     };
       7 
       8     // 通過 obj 調用
       9     var _obj = {
      10         getInfo: function () {
      11             console.log("this === _obj", this === _obj); // true
      12         },
      13     };
      14     _obj.getInfo();
      15 
      16     // 直接調用
      17     function getInfo() {
      18         console.log("this === window", this === window); // true
      19     }
      20     getInfo();
      21 </script>
    2. 後來遇到了面試官,學會了 bind
       1 <script>
       2     // 預定義一個 dom 和 handle
       3     var _html = document.documentElement;
       4     function handle() {
       5         console.log(this);
       6     }
       7 
       8     // 預定義調用者
       9     var _num = 1;
      10     var _obj = {};
      11     var _nul = null;
      12 
      13     // 使用 bind 綁定
      14     var _numHandle = handle.bind(_num);
      15     var _objHandle = handle.bind(_obj);
      16     var _nulHandle = handle.bind(_nul);
      17 
      18     // 都執行一遍
      19     _html.addEventListener("click", _numHandle); // Number {1}
      20     _html.addEventListener("click", _objHandle); // {}
      21     _html.addEventListener("click", _nulHandle); // Window {…}
      22 </script>
    3. 後來發現,如果獨立調用一個函數,使用 bind 太麻煩了,學會了 call,apply,我下麵用 call
       1 <script>
       2     function getInfo() {
       3         console.log(this);
       4     }
       5 
       6     // 預定義調用者
       7     var _num = 1;
       8     var _obj = {};
       9     var _nul = null;
      10 
      11     // 用 call 調用
      12     getInfo.call(_num); // Number {1}
      13     getInfo.call(_obj); // {}
      14     getInfo.call(_nul); // Window {…}
      15 </script>
    4. 可以看到 [call, apply, bind] 綁定 this 的時候對參數做了處理,如果是 null 或 undefined,就綁定 window;如果是簡單數據類型,就用 Object 包裹一下

2. 通過以上經驗做一個推理

  1. this 本來指向它的調用者
  2. 通過 [call, apply, bind] 可以改變 this 指向
  3. 有沒有可能是改變了“調用者”,所以 this 指向了新的“調用者”
  4. 這裡是我的另一篇文章,手動實現 [call, apply, bind],它的實現方式就是改變“調用者”
  5. 可以嘗試手動實現箭頭函數

3. 結論

  1. this 指向調用者
  2. 改變 this 指向的方式是改變調用者
  3. 一路走來,真是返璞歸真啊^O^

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 簡述 Apache Doris 是一個現代化的 MPP 分析型資料庫產品,僅需 亞秒級 響應時間即可獲得查詢結果,能有效地支持實時數據分析。 本文主要介紹如何使用 CloudCanal 快速構建一條穩定高效運行的 PostgreSQL 到 Doris 數據同步鏈路。 技術點 基於 StreamLoa ...
  • 摘要:GaussDB(for Influx)是一款基於計算存儲分離架構,完全相容 InfluxDB 生態的雲原生時序資料庫。 本文分享自華為雲社區《雲資料庫 GaussDB(for Influx) 解密第十一期:讓智能電網中時序數據處理更高效》,作者:華為雲資料庫 GaussDB(for Influ ...
  • CitusData於日前推出了Citus11.0,並宣佈將所有企業版的特性都進行開源。此前,Citus在版本更新時通常會同步發佈2個版本:開源版本和包含一些額外功能的企業版本。“但是,Citus11.0將只有一個版本,因為Citus擴展中的所有內容現在都是完全開源的!” 公告指出,這意味著你現在可... ...
  • 一、引言 理解和分析這個數據包結構(這裡面也涉及廣播間隔時間的設置,設備廣播數據間隔設置長了,會影響設備被髮現的效率;設置短時,又響應功耗)。 我們所說的BLE設備,其實是有區分有兩種角色 Central 和 Peripheral,也就是中心設備和外圍設備。中心設備可以主動連接外圍設備,外圍設備發送 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 相信用過vue的小伙伴,肯定被面試官問過這樣一個問題:在vue中動態的引入圖片為什麼要使用require 有些小伙伴,可能會輕蔑一笑:呵,就這,因為動態添加src被當做靜態資源處理了,沒有進行編譯,所以要加上require, 我倒著都能背 ...
  • 有這樣一道面試題:nextTick是什麼? 我們做如下實驗,在磁碟任意的位置(確保今後可以想起來),新建nextTick文件夾(可以命名為其他的)。 通過命令vue create demo創建以demo命名的vue2項目。 為了方便調試項目,我們通過VS Code打開創建的vue2項目demo。 我 ...
  • 一,面試基礎 HTML和CSS ps:這倆面試答不上來的,基本就可以回去了,以下是HTML題,一般來說這地方不會出太多題,面試官也不願意花太多時間在這上面。 1,HTML語義化,如何理解語義化? 讓人更容易懂(增加代碼的可讀性) 讓搜索引擎更容易懂,有利於爬蟲抓取 在沒有css的情況下,頁面也能更好 ...
  • 本文開始,首先我們來看這兩個詞的意思,provide:提供 inject:註入 用處: 父組件可以向其所有子組件傳入數據,而“不管子組件層次結構有多深(非父子和父子咱都能傳)” 特性: 父組件有一個provide選項來提供數據 子組件有一個inject選項來開始使用這個數據 本文參考組件層級: In ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...