JS 箭头函数的this指向详解

JS 箭头函数的this指向详解

在 JavaScript 中,this是一个非常重要的概念,它代表函数执行时的上下文。而箭头函数作为 ES6 新增的特性之一,虽然与普通函数有些相似之处,但它的this指向却有着很大的不同之处。

箭头函数与普通函数的区别

语法

箭头函数的语法比普通函数更简洁,可以帮助我们更加快速地书写代码,同时也可以减少代码中this指向发生变化的情况。

// 普通函数
function add(a, b) {
  return a + b;
}

// 箭头函数
const add = (a, b) => a + b;

this指向

与普通函数不同,箭头函数没有自己的this值,它的this会继承外层作用域的this

// 普通函数中的this
const obj = {
  name: "Alice",
  sayHi: function () {
    console.log(`Hi, I'm ${this.name}.`);
  },
};
obj.sayHi(); // Hi, I'm Alice.

// 箭头函数中的this
const obj = {
  name: "Alice",
  sayHi: () => {
    console.log(`Hi, I'm ${this.name}.`);
  },
};
obj.sayHi(); // Hi, I'm undefined.

在箭头函数中,this被继承自外层作用域,也就是全局作用域。所以此时this.name实际上是 undefined。

需要注意的是,使用箭头函数并不代表所有情况下都适用,特别是当需要动态绑定this时,我们需要使用普通函数。

箭头函数中的this指向

在理解箭头函数的this指向时,主要分为两种情况讨论:全局作用域下的箭头函数和对象方法中的箭头函数。

全局作用域下的箭头函数

在全局作用域下定义一个箭头函数时,此时它的this指向的是全局对象window

const func = () => {
  console.log(this === window); // true
};
func();

这是因为箭头函数并没有改变this的指向,它的this与最近的普通函数或全局作用域是相同的。此时,最近的普通函数或全局作用域就是全局作用域。

对象方法中的箭头函数

在对象方法中使用箭头函数时,此时它的this指向的是该方法所属的对象。

const obj = {
  name: "Alice",
  sayHi: () => {
    console.log(`Hi, I'm ${this.name}.`);
  },
};
obj.sayHi(); // Hi, I'm undefined.

const obj2 = {
  name: "Bob",
  sayHi: function () {
    console.log(`Hi, I'm ${this.name}.`);
  },
};
obj2.sayHi(); // Hi, I'm Bob.

在第一个例子中,因为箭头函数的this并没有指向obj,而是指向了最近的全局作用域。所以此时this.name是 undefined。而在第二个例子中,因为该函数是普通函数而非箭头函数,它的this指向对象obj2

示例说明

下面的示例说明了箭头函数在不同情况下的this指向。

示例一:定义在全局作用域的箭头函数

const func = () => {
  console.log(this === window); // true
};
func();

该例子定义了一个箭头函数func,该函数定义在全局作用域下,因此该函数中的this指向的是全局对象window。执行该函数后,控制台会依次输出true

示例二:在对象方法中定义箭头函数

const obj = {
  name: "Alice",
  setName: function (name) {
    const set = () => {
      this.name = name;
    };
    set();
  },
};
console.log(obj.name); // Alice
obj.setName("Bob");
console.log(obj.name); // Bob

该例子定义了一个对象obj,该对象包含一个属性name和一个方法setName。在方法setName中,定义了一个箭头函数set,该函数将obj对象的name属性的值修改为传入的name值。通过调用对象方法setName("Bob"),成功将objname属性修改为 Bob。

结语

总而言之,箭头函数是一种有着自己独特特性的函数,它的this指向与普通函数有着很大不同。虽然使用起来很方便,但在某些特定的场景下会出现一些问题。因此,在使用时,我们需要充分理解箭头函数的特性,结合具体的场景进行选择。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JS 箭头函数的this指向详解 - Python技术站

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

相关文章

  • 如何用javascript正则表达式验证身份证号码是否合法

    以下是使用 JavaScript 正则表达式验证身份证号码是否合法的攻略,包含了具体步骤和两条示例: 1. 正则表达式模式 身份证号的验证可以使用正则表达式来实现,身份证号具有一定的规则,我们可以写出相应的正则表达式模式来匹配这些规则。 身份证号码的验证规则如下: 长度为18位; 前17位均为数字; 第18位可以是数字,也可以是大写字母X。 因此,我们可以使…

    JavaScript 2023年5月19日
    00
  • JavaScript Serializer序列化时间处理示例

    下面是“JavaScript Serializer序列化时间处理示例”的完整攻略,包含两个示例说明: 简介 在JavaScript开发中,经常需要对数据进行序列化和反序列化,其中对于时间的处理是比较重要的一部分,在序列化和反序列化中时间需要进行格式转换和传递。本文介绍使用JavaScript进行时间的序列化和反序列化,主要使用了JavaScript Seri…

    JavaScript 2023年5月27日
    00
  • JavaScript DOM常用操作代码汇总

    JavaScript DOM常用操作代码汇总 概述 JavaScript是一种强大的脚本语言,可以用来操作HTML页面中的文本、元素、样式和事件。DOM(Document Object Model)是一种将HTML文档解析成树形结构的API(应用程序接口),使得JavaScript可以对文档中的元素进行访问和操作。本文将提供JavaScript DOM的常用…

    JavaScript 2023年6月10日
    00
  • js 取时间差去掉周六周日实现代码

    要计算时间差并去掉周六周日,我们可以使用 JavaScript 内置的 Date 对象,它提供了许多方法来处理日期和时间。以下是实现这个功能的步骤: 获取开始时间和结束时间的 Date 对象。 我们可以使用 Date 对象的构造函数来创建具有指定日期和时间的日期对象。例如,我们可以这样创建一个代表 2021 年 1 月 1 日的 Date 对象:new Da…

    JavaScript 2023年5月27日
    00
  • JavaScript对象封装的简单实现方法(3种方法)

    下面将详细讲解“JavaScript对象封装的简单实现方法(3种方法)”的完整攻略。 什么是JavaScript对象封装? JavaScript对象封装是指使用面向对象编程的思想,将数据和方法封装在一起,通过暴露公共方法的方式来实现数据的访问和操作保护。 实现JavaScript对象封装的三种方法 1. 利用构造函数实现对象封装 构造函数是一种用于创建对象的…

    JavaScript 2023年5月27日
    00
  • js设置document.domain实现跨域的注意点分析

    关于“js设置document.domain实现跨域的注意点分析”的攻略,我将详细介绍如下: 什么是跨域? 在 Web 开发中,跨域是指在一个域下的文档或脚本试图去请求另一个域下的资源。简单来说,当浏览器向一个网站的服务器发送请求时,如果该请求要访问另外一个域名下的资源(比如 JavaScript 文件、CSS 文件等),那么就会发生跨域问题。 为什么需要跨…

    JavaScript 2023年6月10日
    00
  • JavaScript将数字转换成大写中文的方法

    将数字转换成大写中文是个很实用的功能,在前端开发中经常会遇到这样的需求。以下是详细的攻略: 方案一:使用中文数字字典映射 将数字转换成大写中文可以先通过一个中文数字字典进行映射,然后依次读取数字,并获取对应的中文数字,最后将其拼接成一个字符串即可。 以JavaScript为例,可以编写以下代码: function convertToChinese(num) …

    JavaScript 2023年6月11日
    00
  • Firefox中使用outerHTML的2种解决方法

    下面是详细讲解“Firefox中使用outerHTML的2种解决方法”的完整攻略。 问题描述 当我们想要用 Element.outerHTML 获取某个元素以及其所有子元素的HTML代码时,发现在Firefox浏览器中会出现错误,而在其他浏览器中并不会。经过调查,发现这是因为在Firefox中,outerHTML 并没有被正确实现,导致代码执行出错。 解决方…

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