首页前端开发其他前端知识ES6箭头函数适用于什么地方,使用要注意什么

ES6箭头函数适用于什么地方,使用要注意什么

时间2024-03-25 14:46:04发布访客分类其他前端知识浏览659
导读:在实际案例的操作过程中,我们可能会遇到“ES6箭头函数适用于什么地方,使用要注意什么”这样的问题,那么我们该如何处理和解决这样的情况呢?这篇小编就给大家总结了一些方法,具有一定的借鉴价值,希望对大家有所帮助,接下来就让小编带领大家一起了解看...
在实际案例的操作过程中,我们可能会遇到“ES6箭头函数适用于什么地方,使用要注意什么”这样的问题,那么我们该如何处理和解决这样的情况呢?这篇小编就给大家总结了一些方法,具有一定的借鉴价值,希望对大家有所帮助,接下来就让小编带领大家一起了解看看吧。

简介

箭头函数表达式的语法比函数表达式更简洁,并且没有自己的this,arguments,super或new.target。箭头函数表达式更适用于那些本来需要匿名函数的地方,并且它不能用作构造函数。 ---- MDN

基础用法

参数表示

(param1, param2, …, paramN) =>
 {
 statements }
    
(param1, param2, …, paramN) =>
     expression
//相当于:(param1, param2, …, paramN) =>
{
     return expression;
 }
    

// 当只有一个参数时,圆括号是可选的:
(singleParam) =>
 {
 statements }
    
singleParam =>
 {
 statements }
    

// 没有参数的函数应该写成一对圆括号。
() =>
 {
 statements }
    

返回值表示

let add1 = (num1, num2) =>
 {

  num1 + num2
}
    ;
    
let add2 = (num1, num2) =>
 {

  return num1 + num2
}
    ;
    
let add3 = (num1, num2) =>
     (num1 + num2);
    
let add4 = (num1, num2) =>
     num1 + num2;
    

console.log(add1(2, 3));
      // undefined
console.log(add2(2, 3));
     // 5
console.log(add3(2, 3));
     // 5
console.log(add4(2, 3));
     // 5

进阶

//加括号的函数体返回对象字面量表达式:
let func = () =>
 ({
foo: 'bar'}
    )
console.log(func());
 // {
foo: 'bar'}
    


//支持剩余参数和默认参数
(param1, param2, ...rest) =>
 {
 statements }
    
(param1 = defaultValue1, param2, …, paramN = defaultValueN) =>
 {

statements }


//同样支持参数列表解构
let f = ([a, b] = [1, 2], {
x: c}
 = {
x: a + b}
    ) =>
     a + b + c;
    
f();
  // 6

this

最佳实践

  • 如果必须使用匿名函数,或者inline 回调函数,使用箭头函数。eslint: prefer-arrow-callback, arrow-spacing

why?语法更简洁,并且this更符合预期
如果函数逻辑相当复杂,应当使用命名函数

// bad[1, 2, 3].map(function (x) {
    
  const y = x + 1;
    
  return x * y;
}
    );
    // good[1, 2, 3].map((x) =>
 {
    
  const y = x + 1;
    
  return x * y;
}
    );
    
  • 如果函数体只有一条语句,且该语句不会产生副作用。使用简写方式,隐式返回;或者使用完整写法,显式return。
    eslint: arrow-parens, arrow-body-style
// bad
[1, 2, 3].map(number =>
 {
    
  const nextNumber = number + 1;

  `A string containing the ${
nextNumber}
    .`;

}
    );
    

// good
[1, 2, 3].map(number =>
 `A string containing the ${
number}
    .`);
    

// good
[1, 2, 3].map((number) =>
 {
    
  const nextNumber = number + 1;

  return `A string containing the ${
nextNumber}
    .`;

}
    );
    

// good
[1, 2, 3].map((number, index) =>
 ({

  [index]: number,
}
    ));


// No implicit return with side effects
function foo(callback) {
    
  const val = callback();

  if (val === true) {

    // Do something if callback returns true
  }

}
    

let bool = false;
    

// bad
foo(() =>
     bool = true);
    

// good
foo(() =>
 {
    
  bool = true;

}
    );
    
  • 当表达式占多行时,使用括号括起来增强可读性

why?函数开头和结束更明确

// bad['get', 'post', 'put'].map(httpMethod =>
     Object.prototype.hasOwnProperty.call(
    httpMagicObjectWithAVeryLongName,
    httpMethod,
  ));
    // good['get', 'post', 'put'].map(httpMethod =>
     (
  Object.prototype.hasOwnProperty.call(
    httpMagicObjectWithAVeryLongName,
    httpMethod,
  )));
    
  • 如果函数只有一个参数,省略括号,省略花括号。否则,一直使用完整写法,保持一致性。eslint: arrow-parens
// bad[1, 2, 3].map((x) =>
     x * x);
    // good[1, 2, 3].map(x =>
     x * x);
    // good[1, 2, 3].map(number =>
 (
  `A long string with the ${
number}
    . It’s so long that we don’t want it to take up space on the .map line!`));
    // bad[1, 2, 3].map(x =>
 {
    
  const y = x + 1;
    
  return x * y;
}
    );
    // good[1, 2, 3].map((x) =>
 {
    
  const y = x + 1;
    
  return x * y;
}
    );
    
  • 使用无歧义的=> 语法,与=,> =区分开。eslint: no-confusing-arrow
// badconst itemHeight = item =>
     item.height >
     256 ? item.largeSize : item.smallSize;
    // badconst itemHeight = (item) =>
     item.height >
     256 ? item.largeSize : item.smallSize;
    // goodconst itemHeight = item =>
     (item.height >
     256 ? item.largeSize : item.smallSize);
    // goodconst itemHeight = (item) =>
 {

  const {
 height, largeSize, smallSize }
     = item;
    
  return height >
     256 ? largeSize : smallSize;
    

简单结论

  • 箭头函数不能用new来创建构造函数的实例,普通函数可以(因为箭头函数创建的时候程序不会为它创建construct方法,也就是没有构造能力,用完就丢掉了,不像普通函数重复利用,因此也不需要构造函数原型,也就是不会自动生成prototype属性)

  • 程序不会给箭头函数创建arguments对象

  • 普通函数中的this是动态的,而箭头函数中的this指向的是紧紧包裹箭头函数的那个对象(定义时决定的)

  • 箭头函数不能通过bind、call、apply来改变this的值,但依然可以调用这几个方法(只是this的值不受这几个方法控制)


通过以上内容的阐述,相信大家对“ES6箭头函数适用于什么地方,使用要注意什么”已经有了进一步的了解,更多相关的问题,欢迎关注网络或到官网咨询客服。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

ES6

若转载请注明出处: ES6箭头函数适用于什么地方,使用要注意什么
本文地址: https://pptw.com/jishu/652848.html
PHP代码注释作用有什么,有哪些? php数组如何查询元素位置的?方法是什么?

游客 回复需填写必要信息