ECMAScript2017 [ES8] 新特性收集整理

阅读时长 5 分钟读完

ECMAScript 2017 (ES8) 是 JavaScript 的最新版本,该版本于2017年6月发布。在这个版本中,我们看到了一些重要更新和重大的变化。本文将讨论这些更新和变化,涵盖了它们的详细信息、它们的学习以及指导意义。文章中的示例代码将演示每个更新各自的用法。

异步等待

异步等待是 ES8 中最重要的特性之一。通过 asyncawait 可以更好地编写异步代码。在过去的版本中,我们只能使用回调函数或者 Promise 来解决异步问题,而异步等待让我们写异步代码就像同步代码一样简单。

下面是一个简单的异步调用的例子:

-- -------------------- ---- -------
-------- ---------- -
  ------ --- --------------- -- ------------------- -------
-

----- -------- ------------- -
  ----- -----------
  ------------------ ---------
-

--------------

上述代码示例展示了如何使用异步等待,首先定义了一个 wait 函数,该函数会返回一个 Promise,并在其 resolve 时调用setTimeout。接着,定义了一个 waitThenLog 函数,该函数包含一个 await 表达式,用于等待 wait 函数执行完成。

接下来我们对比看一下 ES8 之前大家常用的 Promise 方式,

-- -------------------- ---- -------
-------- ---------- -
  ------ --- --------------- -- ------------------- -------
-

-------- ------------- -
  ------ ------------------ -- -
    ------------------ ---------
  ---
-

--------------

这样看来,异步等待确实让js代码更简明易读了不少,而且错误调试起来也更加方便。下面我们接着来看下一项重要的特性。

Object.entries() 和 Object.values()

在 ES8 中,我们可以使用 Object.entries()Object.values() 两个新的方法来获取对象自身属性的值。通过这两个方法,我们可以枚举对象中的属性和值。

上述代码示例展示了如何使用 Object.entries()Object.values()Object.entries() 返回对象的属性名和对应的属性值,而 Object.values() 像数组一样返回对象的属性值。这两个方法对于开发人员在处理数据时非常有用。

字符串填充

另一个有用的特性是字符串填充。在ES8之前,我们经常需要使用其他库或手动实现字符串填充。在ES8中,我们现在可以使用 padStart()padEnd() 方法来直接在字符串中填充空白。

上述代码示例展示了如何使用 padStart()padEnd() 方法来在字符串中填充空白。padStart() 方法将一些字符添加到字符串开头,以满足所需的长度,而 padEnd() 是将一些字符添加到字符串的末尾。

非数字属性

在 ES8 中,非数字属性是动态分配的属性。您可以通过类似数组的 push() 方法添加数字属性,就像对象一样添加非数字属性。这让我们可以在处理数据时更灵活、动态和容易操作。

-- -------------------- ---- -------
----- ----- - ---
-------- - ------ ----------
------------- - ----- -- --- - ------ ----------

----------------------
-- ------- ------ ---------

---------------------------
-- ------- ----- -- --- - ------ ---------

上述代码示例展示了如何在对象中添加非数字属性。虽然这在ES8中不是一个新的特点,但它是一个很好的加强功能。非数字属性在处理数据时非常有用,因为它们可以让我们更灵活地添加、删除和更新属性。

其他更新

除了上述这些更新之外,ES8 中还有一些其他更新,如云函数、正则表达式命名捕获组、共享内存和原子操作。这些功能之间的差异很大,因此建议开发人员根据需要查阅相应文档。这些更新提供了更多的方式和工具,使得JavaScript编程比以往更加灵活和强大。

结论

ES8 带来了许多重要的更新,包括异步等待、字符串填充、对象键值的获取,动态分配非数字属性等。这些新特性使JavaScript的开发更加灵活,并使开发人员的代码变得更加清晰和易读。如果您还没有开始使用 ES8 中的这些新特性,那么现在是高时间修改使用它,提高自己的开发技能。

来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6736618d0bc820c58254024d

纠错
反馈