ES6特性:箭头函数

11 篇文章 1 订阅

ES6允许使用"箭头"(=>)定义函数。

基本语法:参数=>函数体

var f = v => v;    //等价于
var f = function(v){
    return v;
};

如果箭头函数不需要参数或需要多个参数,需要使用()括起来

var f = () => 1;  //等价于
var f = function () { return 1 };

var sum = (a,b) => a+b;    //等价于
var sum = function (a,b) { return a+b };

当箭头函数的函数体有多行语句,需要用{}括起来,表示代码块,并且用return来返回值;只有一行一条语句时可以忽略{},结果会自动返回。

var sum = (a,b) =>{
    let num = a+b;
    return num;
}

当箭头函数要返回对象的时候,为了区分于代码块,要用()将对象括起来,否则会报错

let func = (a,b) => { a:a,b:b };    // func(1,2)  报错
let func = (a,b) => ({ a:a,b:b });    // func(1,2)    { a:1,b:2 }

注意:

(1)箭头函数内的this对象,就是定义时所在的对象,而不是使用时所在的对象

function func(){
    setTimeout(()=>{
        console.log(this.a);
    })
}
var a=10;
func();    // 10   此时this指向window
func.call({a:20});    // 20  {a:20}调用func对象的方法

// setTimeout的参数是一个箭头函数,该函数的定义生效是在func函数生成时,箭头函数的this总是指向函数
// 定义生效时所在的对象,即{a:20},所以输出20

(2)不可以作为构造函数,也就是不能使用new命令,否则报错

(3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以使用rest参数代替

rest参数(形式为...变量名),用于获取函数的多余参数,这样就不需要arguments对象了。rest参数搭配的变量是一个数组,该变量将多余的参数放入数组中

function add(...nums){
    let sum=0;
    for(var val of nums){
        sum+=val;
    }
    return sum;
}
add(1,2,3);    // 6

(4)不可以使用yield命令,因此箭头函数不能用作Generator函数

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值