成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JavaScript 的 this 指向,一文解釋清楚

開發
掌握 this 的指向,是理解 JavaScript 核心機制的關鍵,也是成為一名合格的 JavaScript 工程師的必備技能。本文將一次性講清楚 JavaScript 的 this 指向,讓你徹底擺脫 this 的困擾!

this,作為 JavaScript 中最令人困惑的概念之一,常常讓開發者頭疼不已。不同的調用方式、不同的上下文環境,都會導致 this 指向不同的對象。掌握 this 的指向,是理解 JavaScript 核心機制的關鍵,也是成為一名合格的 JavaScript 工程師的必備技能。本文將一次性講清楚 JavaScript 的 this 指向,讓你徹底擺脫 this 的困擾!

一、this 是什么?

簡單來說,this 是一個關鍵字,它指向的是函數執行時的上下文對象。也就是說,this 的值取決于函數是如何被調用的,而不是函數在哪里定義的。

二、this 的四種綁定規則

JavaScript 中 this 的指向主要由以下四種綁定規則決定:

1. 默認綁定 (Default Binding)

示例:

function foo() {
  console.log(this);
}

foo(); // 非嚴格模式下,輸出 window (瀏覽器) 或 global (Node.js)
       // 嚴格模式下,輸出 undefined

"use strict";
function bar() {
  console.log(this);
}

bar(); // 輸出 undefined
  • 在非嚴格模式下,如果函數是獨立調用(即沒有明確的調用者),this 指向全局對象 (瀏覽器中是 window,Node.js 中是 global)。
  • 在嚴格模式下,this 指向 undefined。

2. 隱式綁定 (Implicit Binding)

示例:

如果函數作為對象的方法調用,this 指向調用該方法的對象。

3. 顯式綁定 (Explicit Binding)

示例:

  • 可以使用 call()、apply() 或 bind() 方法來顯式地指定 this 的指向。
  • call() 和 apply() 方法會立即執行函數,并將 this 綁定到指定的對象。它們的區別在于,call() 方法接收一個參數列表,而 apply() 方法接收一個參數數組。
  • bind() 方法會創建一個新的函數,并將 this 永久綁定到指定的對象。新函數不會立即執行,需要手動調用。

4. new 綁定 (new Binding)

示例:

當使用 new 關鍵字調用函數時,會發生以下步驟:

  • 創建一個新的空對象。
  • 將新對象的原型指向構造函數的 prototype 屬性。
  • 將構造函數的 this 綁定到新對象。
  • 執行構造函數中的代碼。
  • 如果構造函數沒有顯式返回一個對象,則返回新對象。

5. 優先級

當多個綁定規則同時適用時,this 的指向由優先級最高的規則決定。優先級從高到低依次為:

  • new 綁定
  • 顯式綁定
  • 隱式綁定
  • 默認綁定

6. 特殊情況

(1) 箭頭函數: 箭頭函數沒有自己的 this,它會從定義時所在的上下文中繼承 this。箭頭函數的 this 無法通過 call()、apply() 或 bind() 方法修改。

示例:

(2) DOM 事件處理函數: 在 DOM 事件處理函數中,this 通常指向觸發事件的 DOM 元素。但可以使用 addEventListener() 方法的 bind() 方法來修改 this 的指向。

示例:

<button id="myButton">Click me</button>

<script>
  const button = document.getElementById("myButton");

  button.addEventListener("click", function() {
    console.log(this); // 輸出: <button id="myButton">Click me</button>
  });

  const obj = {
    name: "MyObject"
  };

  button.addEventListener("click", function() {
    console.log(this.name);
  }.bind(obj)); // 輸出: MyObject
</script>
責任編輯:趙寧寧 來源: JavaScript
相關推薦

2021-10-29 11:30:31

補碼二進制反碼

2022-04-07 08:37:05

鏈表技巧單鏈表

2024-08-09 12:44:45

JavaScript原型鏈鏈條

2022-08-15 15:39:23

JavaScript面向對象數據

2021-09-02 10:24:54

JavaScript前端語言

2024-11-19 13:20:55

2021-12-29 17:38:17

JavaScripttypeof前端

2021-10-11 10:19:48

Javascript 高階函數前端

2021-09-07 09:46:40

JavaScriptGenerator函數

2023-02-28 18:09:53

Javascript定時器

2023-02-23 19:32:03

DOMJavascript開發

2023-01-26 01:09:31

配置數據源參數

2018-05-21 07:08:18

行為驅動開發BDD編碼

2024-04-02 09:38:21

PythonGIL

2019-11-14 09:16:56

物聯網技術路由器

2024-05-21 09:45:40

機器學習人工智能XAI

2019-12-17 08:16:04

JavaScriptthis編程

2021-09-09 10:26:26

Javascript 文檔對象前端

2024-02-23 10:41:29

2019-08-06 09:00:00

JavaScript函數式編程前端
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 在线亚洲人成电影网站色www | 中文字幕一区在线观看视频 | 大象一区 | 久久久久久久久久久爱 | 亚洲精品国产电影 | 天天操操 | 国产精品1区2区3区 中文字幕一区二区三区四区 | 亚洲精品一区二区三区蜜桃久 | 一区二区高清 | 91精品久久久久久久久中文字幕 | 懂色一区二区三区免费观看 | 国产情侣在线看 | 黑人精品欧美一区二区蜜桃 | 亚洲视频在线观看 | 羞羞视频在线观看免费观看 | 国产午夜精品一区二区三区四区 | 国产成人a亚洲精品 | 国产一区二区三区四区区 | 日韩国产在线 | 日韩欧美在线视频 | 啪一啪在线视频 | 成年无码av片在线 | 亚洲精选久久 | 国产激情片在线观看 | 欧美日韩在线一区 | 久久久久国产 | 久久久久成人精品 | 国产乱码精品一区二区三区中文 | 精品一区二区在线观看 | 91精品国产91久久久久游泳池 | 日本成人一区二区 | 中文字幕一区在线 | 欧美一级片a | 午夜激情视频在线 | 一级黄在线观看 | 超碰97免费观看 | 日本精品久久久久久久 | 一区二区三区视频 | 欧美精品在线观看 | 日韩在线观看一区二区三区 | 久久成人综合 |