nodejs中或者其他语言中都会有箭头函数,刚刚开始时候还不知道什么意思。所以下面就来讲解一下。其实很简单
ES6中允许使用“=>”定义函数
var f = v=>v;
//等同于
var f = function(v){
reutrn v;
}
如果箭头函数不需要或者需要多个参数,就使用一个圆括号代表参数部分
var f = ()=>5;
//等同于
var f = function(){ return 5;};
var sum = (num1,num2) => num1+num2;
//等同于
var sum = function(num1,num2){return num1+num2;};
如果箭头函数有多条语句,可以用括号括起来。并且使用return语句返回。
var sum = (sum1,sum2)=>{return num1+num2;};
由于大括号被解释为代码块,所以如果箭头函数直接返回一个对象,必须在对象外边加上括号,否则会报错。
//报错
let getTempItem = id=>{id:id,name:"temp"};
//不报错
let getTempItem = id=>({id:id,name:"temp"});
如果箭头函数只有一句语句,且不需要返回值,可以采用下面的写法,就不用写大括号了。
let fn = ()=>void doesNotReturn():
箭头函数可以与变量解结构结合使用。
const full = ({first,last})=>first+''+last;
//等同于
function full(person){
return person.first+''+person.last;
}
箭头函数使得表达更加简洁
const isEven=n=>n%2===0;
const square=n=>n*n;
箭头函数的一个用处就是简化回调函数
// 正常函数写法
[1,2,3].map(function(x){returnx*x;});
// 箭头函数写法
[1,2,3].map(x=>x*x);
另一个例子
// 正常函数写法
varresult=values.sort(function(a,b){returna-b;});
// 箭头函数写法
varresult=values.sort((a,b)=>a-b);
下面是 rest 参数与箭头函数结合的例子。
const numbers=(...nums)=>nums;
numbers(1,2,3,4,5)
// [1,2,3,4,5]
const headAndTail=(head,...tail)=>[head,tail];
headAndTail(1,2,3,4,5)
// [1,[2,3,4,5]]
使用注意点
箭头函数有几个使用注意点。
(1)函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。
(2)不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。
(3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替。
(4)不可以使用yield命令,因此箭头函数不能用作 Generator 函数。
上面四点中,第一点尤其值得注意。this对象的指向是可变的,但是在箭头函数中,它是固定的。
function foo(){
setTimeout(()=>{console.log("id:",this.id);},100);
}
var id = 21;
foo.call({id:42});
//id:42