JavaScript箭头函数是ECMAScript 6中引入的编写函数表达式的一种简便方法。一般,在JavaScript中,能够经过两种方式建立函数:javascript
能够以下所示建立函数语句:php
function add(num1, num2) { var res = num1 + num2; return res; } var sum = add(7, 2); console.log(sum);
也能够建立相同功能的函数表达式,以下所示:html
var add = function (num1, num2) { var res = num1 + num2; return res; } var sum = add(7, 2); console.log(sum);
ECMA 2015(或ECMA Script 6)引入了更短的语法来编写函数表达式,称为箭头函数。使用箭头函数,你能够将上面的函数表达式编写为:java
var add = (num1, num2) => { return num1 + num2; };
正如你所看到的,使用箭头函数编写的函数表达式更短。函数
首先,参数应该在小括号中传递。你能够建立有两个参数的箭头函数,以下所示:学习
ar add = (num1, num2) => { return num1 + num2; };
若是只要传递一个参数,那么括号是可选的,能够选择忽略。你能够建立一个参数的箭头函数,以下所示:ui
var add = num => { return num * 10; };
若是没有参数,那么你必需要有一个空括号——不能没有。因此对于没有参数的函数,箭头函数是这样写的:this
var add = () => { console.log("hey foo") };
若是函数中有单个表达式或语句:spa
你能够重写add函数,而不使用函数体中的括号和return语句,以下所示:prototype
var add = (num1, num2) => num1 + num2;
你也可使用控制台语句编写不带参数的函数,以下所示:
var add = () => console.log("hey");
JavaScript箭头函数也能够返回对象字面量。惟一的要求是你须要把返回对象装入小括号中,以下所示:
var foo = (name, age) => ({ name: name, age: age }) var r = foo("my cat", 22); console.log(r);
正如你所看到的那样,要返回的对象被放在了小括号内。若是你不这样作,那么JavaScript将没法区分对象字面量和函数体。
JavaScript箭头函数支持另外一个ES6功能:rest参数。你能够在箭头函数中使用rest参数,以下面的代码所示:
var add = (num1, num2, ...restparam) => { console.log(restparam.length); var result = num1 + num2; return result; } var r = add(67, 8, 90, 23); console.log(r);
在这个例子中,当你使用带有rest参数的箭头函数时,输出会是2和75,由于传递的额外参数的数量是2,num1和num2的总和是75。
另外,JavaScript箭头函数还支持另外一个ES6功能:默认参数。此处详细介绍了默认参数。你能够在箭头函数中使用默认参数,以下所示:
var add = (num1 = 9, num2 = 8) => { var result = num1 + num2; return result; } var r = add(); console.log(r);
在上面的代码中,箭头函数中有默认参数。调用该函数时,咱们没有传递任何值,而且因为默认参数的存在,输出将是17。
箭头函数没有它本身的this值。箭头函数中的this值老是从封闭范围继承。在JavaScript中,每一个函数都有它本身的this值,这取决于代码是如何调用函数的。请仔细看下面列出的代码:
var Cat = {
name: 'mew', canRun: function () { console.log(this) var foo = () => { console.log(this) } foo(); } };
在这里,cat是一个对象字面量,它包括:
在canRun方法中,咱们建立了一个箭头函数foo,给出了this值。因为箭头函数没有它本身的this值,因此它将从周围的函数获取,所以,你将获得:
正如你所看到的,this值在canRun方法和箭头函数foo中是相同的。箭头函数从继承范围获得this值。若是你对此不甚清楚,那么请牢记如下两条规则:
应用箭头函数时要注意的一些限制条件:
若是你尝试使用箭头函数做为构造函数,那么你会获得异常。请看下面的代码:
var foo = (name, age) => { name = name, age = age };
var f1 = new foo("cat", 6);
代码试图经过使用箭头函数foo做为构造函数来建立对象f1,JavaScript将抛出如下异常:
并且,当你试图输出箭头函数的原型值时,你会获得undefined的输出:
var foo = (name, age) => { name = name, age = age }; console.log(foo.prototype);
发生这种状况的缘由是由于箭头函数没有原型属性。请记住:虽然箭头函数为你提供了编写函数表达式的简短方法,但它没有本身的this值,也不能用做构造函数。
轻松学习 JavaScript——第 1 部分:了解 let 语句
轻松学习 JavaScript——第 2 部分:函数中的 Rest 参数
轻松学习 JavaScript——第 3 部分:函数中的默认参数
轻松学习 JavaScript——第 4 部分:函数中的 arguments 对象
轻松学习 JavaScript——第 5 部分:简化函数提高
轻松学习 JavaScript——第 6 部分:JavaScript 箭头函数