JS中的箭头函数

yizhihongxing

在JavaScript中,箭头函数是一种简化的函数语法,它在ES6(ECMAScript 2015)引入。箭头函数的语法比传统的function表达式更简洁,同时还有一些特性,例如继承外部作用域的this值。

箭头函数的基本语法如下:

(param1, param2, ..., paramN) => { statements }
(param1, param2, ..., paramN) => expression

 

当箭头函数只有一个参数时,可以省略括号:

param => { statements }
param => expression

 

当函数体只包含一个返回值表达式时,可以省略花括号并直接返回该表达式的值:

(param1, param2) => param1 + param2

 

需要注意的是,箭头函数有以下特性:

1. 没有自己的this值 :箭头函数内的this值继承自包含它的函数作用域,这有助于解决一些this指向问题。
2. 没有arguments对象 :在箭头函数内部,无法访问传统函数中的arguments对象。但你可以使用剩余参数(...rest)语法来获取参数列表。
3. 不能用作构造函数 :箭头函数不能用作构造函数,因此不能使用new运算符实例化。
4. 没有原型 :箭头函数没有prototype属性,因为它们不能作为构造函数使用。

 

更多箭头函数的用法

1. 链式调用:

箭头函数的简洁语法使得在链式调用中使用它们变得更加容易。例如,我们可以在数组上使用多个数组方法并将箭头函数作为回调函数:

const numbers = [1, 2, 3, 4, 5];

const doubledAndFiltered = numbers
  .map(num => num   2)
  .filter(num => num > 5);

console.log(doubledAndFiltered); // [6, 8, 10]

 

2. 事件处理程序:

箭头函数可以方便地用作事件处理程序,因为它们继承了外部作用域的 this 值。这样就避免了使用 bind 来绑定事件处理程序的需要。例如:

class Button {
  constructor() {
    this.buttonElement = document.createElement('button');
    this.buttonElement.textContent = 'Click me!';
    this.buttonElement.addEventListener('click', () => this.handleClick());
    document.body.appendChild(this.buttonElement);
  }

  handleClick() {
    console.log('Button clicked!');
  }
}

const button = new Button();

 

3. 在数组方法中使用:

常见的数组方法,如 filter 、 reduce 、 forEach 等,也可以与箭头函数一起使用,以简化代码并使其更具可读性:

const numbers = [1, 2, 3, 4, 5];

const evenNumbers = numbers.filter(num => num % 2 === 0);

console.log(evenNumbers); // [2, 4]

const sum = numbers.reduce((acc, num) => acc + num, 0);

console.log(sum); // 15

numbers.forEach((num, index) => console.log( Index ${index}: ${num} ));

 

4. 立即调用的箭头函数:

箭头函数还可以作为立即调用函数表达式(IIFE)使用,这在某些场景下有助于限制变量的作用域:

const result = (() => {
  const localVar = 'I am only available within this IIFE';
  return localVar.toUpperCase();
})();

console.log(result); // 'I AM ONLY AVAILABLE WITHIN THIS IIFE'

 

5. 对象字面量和箭头函数:

在箭头函数中直接返回对象字面量时,需要注意语法。由于大括号 {} 在箭头函数中被解释为代码块,而不是对象字面量,因此需要在对象字面量周围添加额外的括号:

const getObject = () => ({ key: 'value' });

console.log(getObject()); // { key: 'value' }

 

6. 多行箭头函数:

虽然箭头函数通常用于简洁的单行函数,但它们也可以用于多行函数。在这种情况下,需要使用大括号包裹函数体,并在需要返回值时使用 return 关键字:

const addWithLogging = (a, b) => {
  console.log( Adding ${a} and ${b} );
  return a + b;
};

console.log(addWithLogging(3, 4)); // 输出 "Adding 3 and 4",然后输出 7

 

7. 箭头函数与解构参数:

箭头函数可以与解构参数一起使用,可以更简洁地处理对象或数组。以下是一些示例:

// 对象解构
const users = [
  { id: 1, name: 'Alice', age: 30 },
  { id: 2, name: 'Bob', age: 25 },
  { id: 3, name: 'Charlie', age: 35 },
];

const getUserNames = users.map(({ name }) => name);
console.log(getUserNames); // 输出:['Alice', 'Bob', 'Charlie']

// 数组解构
const points = [
  [1, 2],
  [3, 4],
  [5, 6],
];

const getDistancesFromOrigin = points.map(([x, y]) => Math.sqrt(x   x + y   y));
console.log(getDistancesFromOrigin); // 输出:[2.23606797749979, 5, 7.810249675906654]

 

8. 箭头函数和 this :

由于箭头函数在其词法作用域内捕获 this 值,因此在某些情况下可能导致问题。例如,在对象方法中使用箭头函数时,它不会获取到对象的 this ,而是捕获到外部作用域的 this 。为了解决这个问题,需要使用传统的 function 声明或表达式。

const obj = {
  value: 10,
  getValue: function() {
    // 正常的function表达式, this  指向obj
    return this.value;
  },
  getValueWithArrow: () => {
    // 箭头函数, this  指向外部作用域(在这种情况下是全局对象或undefined)
    return this.value;
  },
};

console.log(obj.getValue()); // 输出:10
console.log(obj.getValueWithArrow()); // 输出:undefined(严格模式)或全局对象的value属性

 

9. 箭头函数作为高阶函数的参数:

在处理高阶函数时,箭头函数非常有用,因为它们可以使代码更简洁。高阶函数是接受一个或多个函数作为参数、返回一个函数的函数。这里有一个使用箭头函数的高阶函数示例:

const add = a => b => a + b;

const add5 = add(5);
console.log(add5(3)); // 输出:8

在上面的示例中, add 函数接受一个参数 a 并返回一个新的函数,该函数接受另一个参数 b 并返回 a + b 的结果。

10. 不要在所有场景中都使用箭头函数:

尽管箭头函数有很多优点,但并非所有场景都适用。以下是一些避免使用箭头函数的情况:

- 在需要动态上下文的函数(如事件处理程序)中,箭头函数继承了它们的词法作用域。在这种情况下,可能需要使用 function 声明或表达式,以便根据需要访问当前上下文。
- 当需要使用 arguments 对象时,箭头函数不会创建它。在这种情况下,需要使用传统的 function 声明或表达式。

总之,箭头函数的简洁语法和特性使得它们在许多情况下都非常有用,还可以用在setTimeout、错误处理、Promise中等等。但是,在遇到 this 、 arguments 或其他相关问题时,有时可能需要使用传统的 function 声明或表达式来解决特定问题。

 

原文链接:https://www.cnblogs.com/ronaldo9ph/p/17390092.html

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

(0)
上一篇 2023年5月11日
下一篇 2023年5月11日

相关文章

  • 输入一个网址的时候,后台到底发生了一件件什么样的事

    当用户在浏览器中输入一个网址时,后台会经历如下过程: DNS解析 首先,浏览器需要将用户输入的网址转化为一个IP地址,这个过程称为DNS解析。浏览器将会向本地DNS服务器发出请求,本地DNS服务器可能会向上级DNS服务器继续发出请求,直到最终找到负责该域名的DNS服务器,并从中获取对应IP地址。如果本地DNS服务器中不存在对应域名的IP地址,将会继续向上级D…

    JavaScript 2023年6月10日
    00
  • JS实现微信里判断页面是否被分享成功的方法

    实现微信里判断页面是否被分享成功的方法主要需要借助微信JS-SDK提供的能力。以下是实现步骤: 步骤一:引入微信JS-SDK 首先,在网站中引入微信JS-SDK相关代码。代码示例如下: <script src="http://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script…

    JavaScript 2023年6月11日
    00
  • ajax和jsonp跨域的原理本质详解

    针对“Ajax和JSONP跨域的原理本质”这一话题,我准备了以下的完整攻略。 一、同源策略 同源策略,是一种安全策略,它限制了一个源(域名、协议、端口)下的文档或脚本如何能与另一个源(域名、协议、端口)下的资源进行交互。 二、JSONP 跨域 JSONP是一种跨域的技术手段,发起JSONP请求时,服务器端返回指定格式的数据,并在响应中将需要返回的数据作为参数…

    JavaScript 2023年6月11日
    00
  • 深入理解JavaScript中的宏任务和微任务机制

    概述 在JavaScript中,任务的执行分为两种:宏任务和微任务。宏任务和微任务是异步任务的一种处理方式,可以帮助我们合理地安排任务的执行顺序,避免出现项目中遇到的异步问题。 宏任务 宏任务是由浏览器内置的任务处理机制进行处理的,包括:加载事件(如load)、鼠标事件、输入事件、定时器事件等。当浏览器执行完当前宏任务后,才会去检查是否有待处理的微任务,如果…

    JavaScript 2023年6月11日
    00
  • php cookie用户登录的详解及实例代码

    现在我来给您详细讲解“php cookie用户登录的详解及实例代码”的完整攻略。 概述 在网站开发中,登录是一个非常重要的功能。其中,保存用户登录状态的方式有多种,其中之一就是通过使用cookie来保存用户信息。本文将通过示例代码,详细讲解如何使用php cookie来实现用户登录。 实现步骤 步骤一:创建登录页面 首先,我们需要在HTML中创建一个登录页面…

    JavaScript 2023年6月11日
    00
  • Javascript继承(上)——对象构建介绍

    Javascript继承(上)——对象构建介绍 概述 在Javascript中,继承是一种重要的特性。通过继承,我们可以复用已有代码,并且在不改变原有代码的前提下,扩展和改进功能。 本文将介绍Javascript中的对象构建方式,从而为后续讲解继承做好铺垫。 对象创建 在Javascript中可以通过以下方式创建对象: 1.对象字面量 对象字面量是一种简单的…

    JavaScript 2023年5月27日
    00
  • 理解 javascript 中的函数表达式与函数声明

    理解 JavaScript 中的函数表达式与函数声明可以使程序员能够更好地理解 JavaScript 的特性和行为,从而更好地编写 JavaScript 代码。下面是一个完整攻略: 1. 函数表达式与函数声明的定义 在JavaScript中,函数表达式和函数声明都可以用来定义函数。二者的主要区别是函数声明在代码块范围内的提升机制不同。 函数声明会被预处理到程…

    JavaScript 2023年5月27日
    00
  • springboot中JSONObject遍历并替换部分json值

    首先需要明确的是,JSONObject是Java中的一个JSON对象,用于操作JSON数据。在SpringBoot中,我们可以使用Spring的RestController注解来接收并处理JSON数据,然后使用JSONObject进行处理。 接下来,介绍一下如何遍历JSONObject并替换部分json值。一般情况下,我们可以使用迭代器来遍历一个JSONOb…

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