ES6的箭头函数

ES6添加了箭头函数

表达式模式:

ES6

odds  = evens.map(v => v + 1)
pairs = evens.map(v => ({ even: v, odd: v + 1 }))
nums  = evens.map((v, i) => v + i)
复制代码

ES5

odds  = evens.map(function (v) { return v + 1; });
pairs = evens.map(function (v) { return { even: v, odd: v + 1 }; });
nums  = evens.map(function (v, i) { return v + i; });
复制代码

这种模式=>后跟的是一个表达式,也就是函数的返回值。

声明体模式:

ES6

nums.forEach(v => {
   if (v % 5 === 0)
       fives.push(v)
})
复制代码

ES5

nums.forEach(function (v) {
   if (v % 5 === 0)
       fives.push(v);
});
复制代码

这种模式=>后跟的是块级声明{},里面是函数体。

还有一点不同是this的指向,在箭头函数里this是指向其上级函数里的this,例如:

ES6

this.nums.forEach((v) => {
    if (v % 5 === 0)
        this.fives.push(v)
})
复制代码

ES5

var self = this;
this.nums.forEach(function (v) {
    if (v % 5 === 0)
        self.fives.push(v);
});
复制代码
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值