JavaScript 中的 this 绑定规则详解

我将为您详细讲解“JavaScript 中的 this 绑定规则详解”。该攻略将包含以下几个部分:

  1. JavaScript 中的 this 指代什么
  2. this 绑定规则的类型和用法
  3. 示例说明

1. JavaScript 中的 this 指代什么

在 JavaScript 中,this 关键字的值取决于函数的调用方式。this 通常指代当前执行上下文的对象。在全局作用域中,this 指代全局对象(window)。在函数内部,this 还可以指代其他对象,比如函数的调用对象。

2. this 绑定规则的类型和用法

在 JavaScript 中,this 绑定规则包含以下四种类型:

2.1 默认绑定

当函数调用时,如果没有使用任何其他的符合下面三种规则的绑定,那么 this 将会被默认绑定到 window 对象(或全局对象)上。

function foo() {
  console.log(this); // window 对象(或全局对象)
}

foo();

2.2 隐式绑定

当函数作为对象的方法调用时,this 将会被隐式绑定到该对象上。

const obj = {
  name: "张三",
  sayName() {
    console.log(this.name);
  }
};

obj.sayName(); // "张三"

2.3 显式绑定

当使用 call、apply 或 bind 方法时,this 将会被显式绑定到指定的对象上。

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

const obj = { name: "张三" };

foo.call(obj); // "张三"

2.4 new 绑定

当使用 new 关键字调用构造函数时,this 将会被绑定到新创建的对象上。

function Person(name) {
  this.name = name;
}

const obj = new Person("张三");
console.log(obj.name); // "张三"

3. 示例说明

下面分别是两个示例说明:

示例一:隐式绑定

const person = {
  name: "张三",
  sayHi() {
    console.log(`Hi, 我是 ${this.name}`);
  },
  // 对象的方法中返回函数
  getSayHi() {
    return this.sayHi;
  }
};

const person2 = {
  name: "李四"
};

person.getSayHi().call(person2); // Hi, 我是 李四

在上面的示例中,person 对象中的 getSayHi() 方法返回了该对象的 sayHi 方法。当我们使用 call 方法,将 person2 对象作为 this 传递给 getSayHi() 方法的返回值时,this 将会指向 person2 对象。

示例二:显式绑定

function sayHi() {
  console.log(`Hi, 我是 ${this.name}`);
}

const person = {
  name: "张三"
};

const person2 = {
  name: "李四"
};

const boundSayHi = sayHi.bind(person);

boundSayHi(); // Hi, 我是 张三

boundSayHi.call(person2); // Hi, 我是 张三

在上面的示例中,使用 bind 方法将 sayHi 函数绑定到 person 对象上。然后,我们通过调用 boundSayHi() 方法,this 将会指向 person 对象。但是,当我们使用 call 方法并将 person2 对象作为 this 传递给 boundSayHi() 方法时,this 仍然指向 person 对象。这是因为,bind 方法创建的新函数无法被 call 方法覆盖。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript 中的 this 绑定规则详解 - Python技术站

(0)
上一篇 2023年6月10日
下一篇 2023年6月10日

相关文章

  • 利用Blob进行文件上传的完整步骤

    利用Blob进行文件上传的步骤分为以下几步: 1.创建Blob对象 首先需要将文件转换成Blob对象,可以通过 FileReader API 或者使用FormData对象的 append 方法将文件转换成Blob对象,如下所示: // 使用FileReader API将文件转换成Blob对象 const file = document.querySelect…

    JavaScript 2023年6月11日
    00
  • 在JavaScript中使用对数Math.log()方法的教程

    下面是使用对数 Math.log() 方法的教程及示例说明: 使用对数 Math.log() 方法的教程 1. 什么是对数? 对数是数学中重要的概念之一,指数学中某个数(底数)与另一个数(真数)之间的关系式。换句话说,就是求某个底数下的某个真数的幂的指数是多少。 例如,如果要求以2为底数的8的对数,可以表示为2^x=8,那么对数x就是3,即log2(8)=3…

    JavaScript 2023年6月10日
    00
  • javascript 当前日期转化为中文的实现代码

    要将当前日期转化为中文,我们需要使用 JavaScript 的 Date 对象来获取当前日期。然后,我们可以将日期和月份数字转化为中文字符,最后组合起来生成中文日期。下面是实现该功能的完整代码攻略: 步骤一:获取当前日期 使用 JavaScript 的 Date 对象,我们可以获取当前日期的年、月、日: const date = new Date(); co…

    JavaScript 2023年5月27日
    00
  • JavaScript实现简易飞机大战

    下面我将详细讲解“JavaScript实现简易飞机大战”的完整攻略。 前言 在开始编写代码之前,我们需要先了解一下游戏的基本结构和要素,主要包括游戏界面、玩家飞机、敌机、子弹、游戏结束等。在了解了这些基本要素后,我们才能更好的开始编写游戏代码。 游戏界面 游戏的界面主要由背景和玩家飞机、敌机等元素组成。我们可以使用HTML和CSS创建一个游戏界面,其中CSS…

    JavaScript 2023年6月11日
    00
  • JS sort排序详细使用方法示例解析

    JS sort排序详细使用方法示例解析 在 Javascript 中,sort() 是一个常用的排序函数。sort() 可以按照数组元素的字母排序,也可以按照数字大小排序。 sort() 语法 sort() 函数的语法如下: array.sort(sortFunction) 其中,sortFunction 是可选的参数。如果省略该参数,那么 sort() 函…

    JavaScript 2023年6月11日
    00
  • js字符串转json对象的四种实现方法

    下面是关于“JS字符串转JSON对象的四种实现方法”的详细攻略。 概述 在前端开发中,我们经常需要将字符串转换为JSON对象。这时候,使用JavaScript提供的JSON对象提供了很好的支持。下面,我们将介绍四种将JS字符串转化为JSON对象的实现方法。 方法一:使用eval函数 let str = ‘{"name": "ap…

    JavaScript 2023年5月27日
    00
  • 详解javascript事件冒泡

    详解JavaScript事件冒泡攻略 在JavaScript中,事件冒泡是指当一个元素触发了某个事件时,该事件将传递到该元素的祖先元素,一直到HTML文档的根节点。这意味着如果您不阻止事件冒泡,那么在触发最底层元素的事件时,将触发所有父元素的事件。在本教程中,我们将详细讨论Javascript事件冒泡和如何在代码中实现它。 什么是事件冒泡 事件冒泡是一种机制…

    JavaScript 2023年6月10日
    00
  • 通过实例解析json与jsonp原理及使用方法

    通过实例解析JSON与JSONP原理及使用方法 什么是JSON JSON(JavaScript Object Notation)即 JavaScript 对象表示法,是一种轻量级的数据交换格式,易于阅读和编写。JSON采用基础元素(值value,列表list/array,对象object)来描述数据对象,因此可以表示复杂的数据结构。 JSON的基本语法 在J…

    JavaScript 2023年5月27日
    00
合作推广
合作推广
分享本页
返回顶部