轻松学习 JavaScript(6):JavaScript 箭头函数

来源:互联网 发布:淘宝楠楠家是洋垃圾 编辑:程序博客网 时间:2024/06/05 16:50

(点击上方公众号,可快速关注)

英文: Dhananjay Kumar   译文:码农网/小峰

http://www.codeceo.com/article/easy-javascript-05-hoisting.html

如果好文章投稿,点击 → 了解详情


  • 《轻松学习 JavaScript (1):了解 let 语句》

  • 《轻松学习 JavaScript (2):函数中的 Rest 参数》

  • 《轻松学习 JavaScript (3):函数中的默认参数》

  • 《轻松学习 JavaScript (4):函数中的 arguments 对象》

  • 《轻松学习 JavaScript (5):简化函数提升》


JavaScript箭头函数是ECMAScript 6中引入的编写函数表达式的一种简便方法。通常,在JavaScript中,可以通过两种方式创建函数:


  • 函数语句。

  • 函数表达式。


可以如下所示创建函数语句:


functionadd(num1,num2){

    varres = num1 + num2;

    returnres;

}

varsum = add(7,2);

console.log(sum);


也可以创建相同功能的函数表达式,如下所示:


varadd = function(num1,num2){

    varres = num1 + num2;

    returnres;

}

varsum = add(7,2);

console.log(sum);


ECMA 2015(或ECMA Script 6)引入了更短的语法来编写函数表达式,称为箭头函数。使用箭头函数,你可以将上面的函数表达式编写为:


var add = (num1, num2) => { return num1 + num2; };


正如你所看到的,使用箭头函数编写的函数表达式更短。


箭头函数的基本语法规则


首先,参数应该在小括号中传递。你可以创建有两个参数的箭头函数,如下所示:


var add = (num1, num2) => { return num1 + num2; };


如果只要传递一个参数,那么括号是可选的,可以选择忽略。你可以创建一个参数的箭头函数,如下所示:


var add = num => { return num * 10; };


如果没有参数,那么你必须要有一个空括号——不能没有。所以对于没有参数的函数,箭头函数是这样写的:


var add = () => { console.log("hey foo") };


如果函数中有单个表达式或语句:


  • 在主体中使用括号是可选的。

  • 使用return语句是可选的。


你可以重写add函数,而不使用函数体中的括号和return语句,如下所示:


var add = (num1, num2) => num1 + num2;


你也可以使用控制台语句编写不带参数的函数,如下所示:


var add = () => console.log("hey");


返回对象字面量


JavaScript箭头函数也可以返回对象字面量。唯一的要求是你需要把返回对象装入小括号中,如下所示:


varfoo = (name,age) => ({

    name:name,

    age:age

})

varr = foo("my cat",22);

console.log(r);


正如你所看到的那样,要返回的对象被放在了小括号内。如果你不这样做,那么JavaScript将无法区分对象字面量和函数体。


箭头函数支持rest参数


JavaScript箭头函数支持另一个ES6功能:rest参数。你可以在箭头函数中使用rest参数,如下面的代码所示:


varadd = (num1,num2,...restparam) => {

    console.log(restparam.length);

    varresult = num1 + num2;

    returnresult;

}

varr = add(67,8,90,23);

console.log(r);


在这个例子中,当你使用带有rest参数的箭头函数时,输出会是2和75,因为传递的额外参数的数量是2,num1和num2的总和是75。


箭头功能支持默认参数


另外,JavaScript箭头函数还支持另一个ES6功能:默认参数。此处详细介绍了默认参数。你可以在箭头函数中使用默认参数,如下所示:


varadd = (num1 = 9,num2 = 8) => {

    varresult = num1 + num2;

    returnresult;

}

varr = add();

console.log(r);


在上面的代码中,箭头函数中有默认参数。调用该函数时,我们没有传递任何值,并且由于默认参数的存在,输出将是17。


“this”在箭头函数中如何工作?


箭头函数没有它自己的this值。箭头函数中的this值总是从封闭范围继承。在JavaScript中,每个函数都有它自己的this值,这取决于代码是如何调用函数的。请仔细看下面列出的代码:


varCat = {

    name:'mew',

    canRun:function(){

        console.log(this)

        varfoo = () => {console.log(this)}

        foo();

    }

};


在这里,cat是一个对象字面量,它包括:


  • 属性名称。

  • 方法canRun。


在canRun方法中,我们创建了一个箭头函数foo,给出了this值。由于箭头函数没有它自己的this值,所以它将从周围的函数获取,因此,你将得到:



正如你所看到的,this值在canRun方法和箭头函数foo中是相同的。箭头函数从继承范围得到this值。如果你对此不甚清楚,那么请牢记以下两条规则:


  • 使用object.method在方法中获取一个有意义的对象作为this值。

  • 对于任何其他要求,使用箭头函数,由于函数没有自己的this值,所以它将继承封闭范围的this值。


使用箭头函数的限制条件


应用箭头函数时要注意的一些限制条件:


  • 箭头函数没有参数对象。

  • 箭头函数不能与新运算符一起使用,因此它不能用作构造函数。

  • 箭头函数没有原型属性。


如果你尝试使用箭头函数作为构造函数,那么你会得到异常。请看下面的代码:


varfoo = (name,age) => {name = name,age = age};

varf1 = newfoo("cat",6);


代码试图通过使用箭头函数foo作为构造函数来创建对象f1,JavaScript将抛出以下异常:

 


arrowimg2而且,当你试图输出箭头函数的原型值时,你会得到undefined的输出:


varfoo = (name,age) => {name = name,age = age};

console.log(foo.prototype);


发生这种情况的原因是因为箭头函数没有原型属性。请记住:虽然箭头函数为你提供了编写函数表达式的简短方法,但它没有自己的this值,也不能用作构造函数。



觉得本文对你有帮助?请分享给更多人

关注「前端大全」,提升前端技能