JavaScript全解析——this指向

来源:https://www.cnblogs.com/qian-fen/archive/2023/05/11/17391354.html
-Advertisement-
Play Games

本系列內容為JS全解析,為千鋒教育資深前端老師獨家創作 致力於為大家講解清晰JavaScript相關知識點,含有豐富的代碼案例及講解。如果感覺對大家有幫助的話,可以【點個關註】持續追更~ this指向(掌握) this 是一個關鍵字,是一個使用在作用域內的關鍵字 作用域分為全局作用域和局部作用域(私 ...


本系列內容為JS全解析,為千鋒教育資深前端老師獨家創作

致力於為大家講解清晰JavaScript相關知識點,含有豐富的代碼案例及講解。如果感覺對大家有幫助的話,可以【點個關註】持續追更~

this指向(掌握)

this 是一個關鍵字,是一個使用在作用域內的關鍵字

作用域分為全局作用域和局部作用域(私有作用域或者函數作用域)

全局作用域

全局作用域中this指向window

局部作用域

函數內的 this, 和 函數如何定義沒有關係, 和 函數在哪定義也沒有關係,只看函數是如何被調用的(箭頭函數除外)

可分為以下場景:

普通函數中調用

普通函數中的this和全局調用一樣,this指向window

語法:函數名()

<script>
    // 全局使用 this 
    console.log(this) //window 
    console.log(window) //window 
    console.log(window === this) //true 
    //普通函數調用 
    function fn() { 
        console.log('我是全局 fn 函數') 
        console.log(this) //window 
    } 
    fn() 
</script>

對象(包含數組)中調用

該函數內的 this 指向 前面的內容,也就是那個對象或者數組

語法:

對象名.函數名()*

對象名

<script> 
    //對象函數調用 
    function fn() { 
        console.log(this) //{fun: ƒ} 
    } 
    var obj = { 
        fun: fn 
    } 
    obj.fun() 
    obj['fun']() 
</script>

定時器處理函數中調用

定時器中的this同樣也是指向window

<script> 
    // 定時器處理函數 
    setTimeout(function() { 
        console.log(this); //window 
    }, 1000) 
</script>

事件處理程式中調用

事件處理程式中的this指向的是事件源

<!DOCTYPE html> 
<html lang="en"> 

<head> 
   <meta charset="UTF-8"> 
   <meta http-equiv="X-UA-Compatible" content="IE=edge"> 
   <meta name="viewport" content="width=device-width, initial-scale=1.0">        <title>Document</title> 
   <style> 
       div { 
           width: 200px; 
           height: 200px; 
           background-color: red; 
        } 
    </style> 
</head> 

<body> 
   <div>hello world</div> 
   <script> 
       var res = document.querySelector('div') 
       
       res.onclick = function() { 
           console.log(this); //<div></div>
       } 
   </script> 
</body> 

</html>

自執行函數中調用

●自執行函數中的this也指向window

<script> 
    (function() { 
        console.log(this); //window 
    })() 
</script>

強行改變this指向

通過上面的學習大家知道,this在不同的情況指向是不同的,但是有時候需要指向一個制定的對象,這就需要改變this的指向

可以理解成不管之前指向哪裡,現在我讓你指向哪裡你就要指向哪裡

強行改變this指向的方式可以通過call、apply和bind來改變

call調用

作用:改變函數內部this的指向

語法:

函數名.call()

對象名.函數名.call(參數1,參數2,參數3...)

參數:

○第一個參數是this要指向的對象

○從第二個參數開始,依次給函數傳遞實參

特點: 會立即調用函數或者說立即執行

<script> 
    function fn(a, b) { 
        console.group('fn 函數內的 列印') 
        console.log('this : ', this) 
        console.log('a : ', a) 
        console.log('b : ', b) 
        console.groupEnd() 
    } 
    var obj = { 
        name: '我是 obj 對象' 
    } 
    var arr = [100, 200, 300, 400, 500] 
    // 用 call 調用 
    fn.call(obj, 100, 200) 
    fn.call(arr, 1000, 2000) 
    /* 
    this : {name: '我是 obj 對象'} 
    a : 100 
    b : 200 
    fn 函數內的 列印 
    this : (5) [100, 200, 300, 400, 500] 
    a : 1000 
    b : 2000 
    */ 
</script>

apply調用

作用: 改變函數內部this的指向

語法:

○函數名.apply()
○對象名.函數名.apply(參數1,[參數2,參數3...])

參數:

○第一個參數是this要指向的對象

○第二參數的一個數組,要傳遞的實參要放到數組裡面,就是有一個實參也要放到數組裡面

特點: 會立即調用函數或者說立即執行

<script> 
    function fn(a, b) { 
        console.group('fn 函數內的 列印') 
        console.log('this : ', this) 
        console.log('a : ', a) 
        console.log('b : ', b) 
        console.groupEnd() 
     } 
     var obj = { 
         name: '我是 obj 對象' 
     } 
     var arr = [100, 200, 300, 400, 500] 
     // 用 apply 調用 
     fn.apply(obj, [100, 200]) 
     fn.apply(arr, [1000, 2000]) 
     /* 
     fn 函數內的 列印 
      this : {name: '我是 obj 對象'} 
      a : 100 
      b : 200 
      fn 函數內的 列印 
      this : (5) [100, 200, 300, 400, 500] 
      a : 1000 
      b : 2000 
      */ 
</script>

bind調用

作用: 改變函數內部this的指向

語法:

函數名.bind()

對象名.函數名.bind(參數1,參數2,參數3...)

參數:

第一個參數是this要指向的對象

從第二個參數開始,依次給函數傳遞實參

特點: 函數不會立即調用,會返回一個改變this指向以後的函數,使用的時候需要調用

<script> 
    function fn(a, b) { 
        console.group('fn 函數內的 列印') 
        console.log('this : ', this) 
        console.log('a : ', a) 
        console.log('b : ', b) 
        console.groupEnd() 
     } 
     var obj = { 
         name: '我是 obj 對象' 
     } 
     var arr = [100, 200, 300, 400, 500] 
     // 用 bind 調用 
     // 註意: 因為是 bind, 不會把 fn 函數執行, 而是把 fn 
     // res 接受的就是 bind 方法複製出來的 fn 函數, 和 fn 
     var res = fn.bind(obj, 100, 200) 
     var res1 = fn.bind(arr, 1000, 2000) 
     res() 
     res1() 
     /* 
     fn 函數內的 列印 
     this : {name: '我是 obj 對象'} 
     a : 100 
     b : 200 
     fn 函數內的 列印 
     this : (5) [100, 200, 300, 400, 500] 
     a : 1000 
     b : 2000 
     */ 
</script>

以上即為JS中this指向的一些基礎知識點,更多技術乾貨、知識技巧可以關註我們!有不清楚的問題也可以在評論區交流討論,也可以私信小千~


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

-Advertisement-
Play Games
更多相關文章
  • (Oracle 定時任務job實際應用) 一、Oracle定時任務簡介 Oracle定時任務是在oracle系統中一個非常重要的子系統,運用得當,可以大大提高我們系統運行和維護能力。oracle定時任務的功能,可以在指定的時間點自行執行任務。 那麼在實際工作中,什麼樣的場景會用到定時任務呢?下麵是在 ...
  • HUAWEI Health Kit為開發者提供用戶自定義的跑步課程導入介面,便於用戶在華為運動健康App和華為智能穿戴設備上查看來自生態應用的訓練課表,開啟科學、適度的運動訓練。 跑步課程導入能力支持生態應用在獲取用戶的華為帳號授權後,將跑步課程數據寫入至華為運動健康App,併在已有的華為智能穿戴設 ...
  • 京喜APP早期開發主要是快速原生化迭代替代原有H5,提高用戶體驗,在這期間也積累了不少性能問題。之後我們開始進行一些性能優化相關的工作,本文主要是介紹京喜圖片庫相關優化策略以及關於圖片相關的一些關聯知識。 ...
  • 廣告是App開發者最常用的流量變現方法之一,當App擁有一定數量用戶時,開發者就需要考慮如何進行流量變現,幫助App實現商業可持續增長。 鯨鴻動能流量變現服務是廣告服務依托華為終端強大的平臺與數據能力為開發者提供的App流量變現服務,開發者通過該服務可以在自己的App中獲取並向用戶展示精美的、高價值 ...
  • 源碼 https://github.com/webabcd/flutter_demo 作者 webabcd 一統天下 flutter - 插件: flutter 使用 web 原生控制項,並做數據通信 示例如下: lib\plugin\plugin2.dart /* * 插件 * 本例用於演示 flu ...
  • 一、本文想給你聊的東西包含一下幾個方面:(僅限於es6之前的語法哈,因為es6裡面class這關鍵字用上了。。) 1.原型是啥?原型鏈是啥? 2.繼承的通用概念。 3.Javascript實現繼承的方式有哪些? 二、原型是啥?原型鏈是啥? 1.原型是函數本身的prototype屬性。 首先js和ja ...
  • 背景: 本來項目開發系統防掛機功能,在其餘游覽器中均可以使用。但是呢在蘋果的safair游覽器中會出現幾率失效,最後經過排查發現是蘋果的墓碑機制導致。即:此標簽頁活躍,其他標簽頁假死。然後就導致防掛機失效了。 原理: 假如當前游覽器中有3個標簽頁分別是A,B,C,每個標簽頁都有倒計時。正常情況下,每 ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 Vue3+TS(uniapp)手擼一個聊天頁面 前言 最近在自己的小程式中做了一個智能客服,API使用的是雲廠商的API,然後聊天頁面...嗯,找了一下關於UniApp(vite/ts)版本的好像不多,有一個官方的但其中的其他代碼太多了, ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...