箭头函数
5.18
1.箭头函数:
==函数声明尽量使用箭头函数的方式==
绝大多数情况下都可以用=> 代替function来声明函数。
=>函数的作用已经完全包围了function,并且this指向清晰。
vue react里 this是一个高频使用的model。
vue里就出现了一种=>代替不了function的情况: 在声明data和生命周期函数中如:mounted,created等的情况下,依然要用function或函数名+()的方式来声明函数。
(这个跟vue作者尤雨溪当年在google angular项目组的一个bug有关,他在这里规避掉了箭头函数声明的情况)
- 更简短的函数并且不绑定
this
1 | var elements = [ |
箭头函数可以用于当函数体只有一个return语句的时候,省略return,直接element => element.length
省略了function(element){return}等语句。
this的指向:
- 构造函数,this指向创建的新对象
- 严格模式下的函数调用,this指向undefined
- 对象方法,它的this指向这个对象…
setInterval()方法:创建计时器,函数每次调用会在延迟后进行。
下面是this指向的不同:
1 | function Person() { |
通过将this值分配给封闭的变量,可以解决this问题。将this指向的对象传递给that,而下面的函数是可以获取到that的值的,因此这个方式可以解决this指向不同的问题。
1 | function Person() { |
箭头函数不会创建自己的this,它只会从自己的作用域链的上一层继承this。因此,在下面的代码中,传递给setInterval的函数内的this与封闭函数中的this值相同:
1 | function Person(){ |
=> 的用处就显现出来了,他可以继承上一层的this,这样就不需要定义that去做更多不容易理解的操作了。
更多:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Functions/Arrow_functions
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来源 一叶凉夏!






