es6 标准新增了一种新的函数:Arrow Function (箭头函数) 它的定义用的就是一个箭头 x=>x*x 上面的箭头函数相当于: function(x){ return x*x; }
箭头函数相当于匿名函数,并且简化了函数的定义。箭头函数有两种格式,一种像上面的,只包含一个表达式,连{….}和return 都省略掉了。还有一种可以包含多条语句,这时候就不能省略{…}和return; x=>{ if(x>0){ return x*x; }else{ return -x*x; } } 如果参数不是一个,就需要用括号()括起来 //两个参数 (x,y)=>x*x+y*y
如果要返回一个对象,就要注意 ,如果是单表达式,这么写的话会报错: x=>{foo:x} 因为和函数体的{…}有语法冲突,所以要改为: x=>({foo:x})
this 箭头函数看上去是匿名函数的一种简写,但实际上,箭头函数和匿名函数有个明显的区别: 现在箭头函数完全修复了this的指向,this总是指向词法作用域,也就是外层调用者obj: 由于this在箭头函数中已经按照词法作用域绑定了,所以用call()或者apply()调用箭头函数时,无法对this进行绑定,即传入的第一个参数被忽略:
generator(生成器)是ES6标准引入的新的数据类型,一个generator看上去像一个函数,但看看返回很多次 函数在执行过程中,如果没有遇到return语句(函数末尾如果没有return,就是隐含的return undefined)