# 箭头函数 ## 定义 ES6允许使用“箭头”(=>)定义函数。 ```javascript var f = v => v; ``` 上面的箭头函数等同于: ```javascript var f = function(v) { return v; }; ``` 如果箭头函数不需要参数或需要多个参数,就使用一个圆括号代表参数部分。 ```javascript var f = () => 5; // 等同于 var f = function (){ return 5 }; var sum = (num1, num2) => num1 + num2; // 等同于 var sum = function(num1, num2) { return num1 + num2; }; ``` 如果箭头函数的代码块部分多于一条语句,就要使用大括号将它们括起来,并且使用return语句返回。 ```javascript var sum = (num1, num2) => { return num1 + num2; } ``` 由于大括号被解释为代码块,所以如果箭头函数直接返回一个对象,必须在对象外面加上括号。 ```javascript var getTempItem = id => ({ id: id, name: "Temp" }); ``` ##实例:回调函数 箭头函数的一个用处是简化回调函数。 ```javascript // 正常函数写法 [1,2,3].map(function (x) { return x * x; }); // 箭头函数写法 [1,2,3].map(x => x * x); ``` 另一个例子是 ```javascript // 正常函数写法 var result = values.sort(function(a, b) { return a - b; }); // 箭头函数写法 var result = values.sort((a, b) => a - b); ``` ## 注意点 箭头函数有几个使用注意点。 - 函数体内的this对象,绑定定义时所在的对象,而不是使用时所在的对象。 - 不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。 - 不可以使用arguments对象,该对象在函数体内不存在。 关于this对象,下面的代码将它绑定定义时的对象。 ```javascript var handler = { id: "123456", init: function() { document.addEventListener("click", event => this.doSomething(event.type), false); }, doSomething: function(type) { console.log("Handling " + type + " for " + this.id); } }; ``` 上面代码的init和doSomething方法中,都使用了箭头函数,它们中的this都绑定handler对象。否则,doSomething方法内部的this对象就指向全局对象,运行时会报错。