ES6箭头函数适用于什么地方,使用要注意什么
导读:在实际案例的操作过程中,我们可能会遇到“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();
// 6this
最佳实践
- 如果必须使用匿名函数,或者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箭头函数适用于什么地方,使用要注意什么
本文地址: https://pptw.com/jishu/652848.html
