JavaScript ES6为JavaScript语言添加了许多新功能,其中一些功能比其他功能更具开创性和广泛应用。
例如
ES6 Classes之类的
东西
,虽然新颖,但只是在现有的方法基础上添加语法糖,以便在JavaScript中创建类,而像Generators这样的功能虽然功能非常强大,但却保留用于更专业的任务。
1)JavaScript箭头功能
ES6 JavaScript中我最喜欢的一个新功能并不是一个新功能,而是一个令人耳目一新的新语法集,每次我使用它时都会在我脸上露出笑容。 我在谈论Arrow函数,它提供了一种在JavaScript中定义匿名函数的极其优雅和简约的方法。
简而言之,Arrow函数会删除“
function
”关键字,并使用箭头(
=>
)
将函数
的
参数部分与
匿名
函数
的函数BODY
分开
:
这相当于:
要么:
这与:
使用传统的匿名函数时,箭头函数也会删除错误的关键源,这是
this
函数内部
“
”对象的值。
使用箭头函数,“
this
”是词法绑定的,这
只是一种说法,它的值与父作用域绑定,并且从不改变。
如果
在自定义对象“
”中
定义
了
箭头
函数,则“
countup
”的值
this
指向“
countup
” - 不需要猜测。
例如:
将其与传统的匿名函数进行比较,其中“
this
”
的值
根据其定义的上下文而变化。
this.counter
在上述情况下
尝试引用时的结果
将返回
undefined
,这种行为可能会混淆许多不熟悉动态错综复杂的行为捆绑。
使用箭头功能,“
this
”
的值
始终可预测且易于推断。