箭头函数写法可以有:
var fn = n=>{}; 只有一个参数可以不写括号
var fn = ()=>'hello'; 没有参数要写括号,如果直接返回值可以写。
建议按照常规写法。
箭头函数 不存在argument,如果要用请...rest参数代替。
箭头函数的this=>箭头函数的this永远指向上一个不是箭头函数的函数的this
说明:自定义函数指向的对象都是window
function add(){
setTimeout(function(){
console.log(this.id)
},2000);
// 用function方式定义,使用的时候this指向的是window。得到的是1
setTimeout(()=>console.log(this.id),200);
// 箭头函数定义,使用的时候this执行的是函数对象也就是{"id":32},得到的id是32
// (意思是此时this不指向window,而是指向add这个对象)
}
window.id=1; // => 等价于var id =1;
add.call({"id":23})
总结:
(1)函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。
(2)不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。
(3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用...rest参数代替。