箭头函数简化了原生写法,让代码更加简洁,来看一下基础的写法
箭头函数写法
基础写法
函数的写法也就是比原生的写法少了function多了箭头,所以这可能就是箭头函数的由来吧!
简化写法
1) 当形参有且只有一个的时候,可以省略小括号
2)当代码体只有一条语句的时候可以省略花括号
注意:此时return必须省略,而且语句的执行结果就是函数的返回值
使用箭头函数注意事项
1.不能作为构造实例化对象
此时会报错
2.不能使用arguments变量
此时会显示arguments未定义
this相关问题
可以看一下对this指向的介绍全面解析this指向问题,更方便理解。
箭头函数不适用this的四种标准规则,而是根据外层(函数或全局)作用域来决定this的
this是静态的。this始终指向函数声明时所在作用域下的this的值。
我们直接调用的话,this指向window,则会打印angula,而使用call对this进行绑定之后,我们会发现,普通的写法this发生了改变,打印obj name,但是箭头函数的this并未发生改变,依旧打印angula。
来进行一个小实践
1.实现一个小功能,点击div之后,将div块的背景颜色设置为red
这是我们原本的写法,不使用箭头函数,这时候需要保存一下this,不然直接使用this会指向window。
箭头函数写法
这时候就不需要再对this进行保存了。这时候是不是感觉简化了好多呢?
2.从数组中返会偶数的元素
是不是感觉这么简单的东西写起来要这么多东西,那么来看一下箭头函数的写法
这时候会简单一点点,那么我们来看一下箭头函数简化之后的写法
这时候是不是感觉一切努力都不会白费,箭头函数可以使得代码变得更加的简洁呢?
总结:
箭头函数适合与this无关的回调,如定时器,数组的方法回调
不适合与this有关的回调,如事件回调,对象的方法,当然不适合并不是说不能使用箭头函数
————————————————
版权声明:本文为CSDN博主「web_angula」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:
ES6之箭头函数_前端~米老鼠的博客-CSDN博客blog.csdn.net