关于 ECMAScript 2015(ES6)的一些有用的提示和技巧

原文:https://www.oschina.net/translate/check-out-these-useful-ecmascript-2015-es6-tips-and-tricks
EcmaScript 2015(又名 ES6 )已经发布好几年了,各种新功能现在都能以灵巧的方式使用。我想列出并讨论其中的一些我认为会对大家有所帮助的实用功能。

如果你还知道其它技巧,请评论回复,我很乐意将其添入进来。

1. 强化对必需参数的要求

ES6 提供了默认参数值,支持你设置一些默认值,以便在没有该参数的情况下调用该函数时使用。

在下图示例中,我们将 required() 函数的 a 和 b 参数设置默认值。这意味着如果 a 或 b 未被传递,那么 required() 函数将在调用时得到一个错误。

2. 强大的 “reduce”

Array 的 reduce 方法应用范围非常广泛。它通常用于将一组数据转换成一个单一的值。其实你还可以用它干更多的事情。

注:大多数技巧都依赖于初始值的形态,它是数组或对象,而不是像字符串或变量这样的简单值。

2.1 使用 reduce 同时进行映射和过滤

假设有么这一个用例,有一个列表,你想修改其中的每一项(也就是映射)然后过筛选来其中一些(即过滤)。这个过程需要你对列表进行两次遍历!

下面这个示例中,我们把数组中的每项的值翻倍,然后选出所有大于 50 的值。注意,我们是如何使用强大的 reduce 方法来同时进行翻倍(映射)和过滤的?那是非常有效的办法。

2.2 使用 “reduce” 代替 “map” 或 “filter”

如果你仔细观察了上面的例子(在2.1中),你就知道 reduce 可用于遍历各项并对其进行过滤或映射! 

2.3 使用 reduce 匹配括号Using reduce to balance parentheses

这里还有一个关于 reduce 普适性的例子。有一个包括括号的字符串,我们知道这些括号是否都相互匹配,即“(”和“)”的数量是否相等,而且“(”是否在“)”之前出现。

我们可以像下面这样用 reduce 轻松解决。我们需要一个叫 counter 的变量用作计数器,其初始值为 0。如果我们遇到 ( 就加 1,遇到 ( 就减 1。如果它们完全匹配,我们最后会得到一个 0 值。

2.4 统计数组中重复数据 (数组 → 对象转换)

有时你需要统计数组中重复的数据,或将数组转换为对象,你就可以使用reduce了。

以下案例,我们将要统计有多少种类的汽车类型并将这些数据放置到一个对象中。

此外,reduce还有很多方面的应用,我推荐你阅读MDN所示的案例。

3. 对象解构

3.1 删除不想要的属性

很多时候,当你想要删除不想要的属性——可能会因为他们包含敏感信息或者就是因为他们太大了。在 *rest* 参数中,除了迭代整个对象来删除他们这个方法之外,我们还可以简单地提取这些属性变量,以保持有用的。

在下面例子中,我们想要删除 _internal 和 tooBig 属性。我们会给 _internal 和 tooBig 变量赋值并存储,之后,我们再使用 *rest* 参数 cleanObject 。


3.2 在函数参数中使用解构

下面的示例中的 engine 属性是 car 对象中的一个嵌入对象。如果说我们需要 engine 的 vin 属性的话,可以像下面这样使用解构轻松实现。

3.3 合并对象

ES6 带来了扩展运算符(用 3 个点表示)。它通常用于解构数组的值,不过它也可以用在对象上。

下面的例子中,我们新对象中使用扩展运算符来扩展对象。第 2 个对象中的键值对会覆盖第 1 个对象中的键值对 [译者注:如果键名相同的话]。

下面示例中第 object2 的 b 和 c 两个键值对覆盖了 object1 中的同名键值对。

4. Sets

4.1 使用Sets去重

ES6中可以很容易的使用Sets去除重复数据,Sets只允许保存唯一数据。

4.2 使用数组的方法

将Sets转换为数组只需要简单的使用的一个展开运算符( )。同时你也能在Sets里使用所有数组相关的方法。

如以下Set,我们只想保留所有大于3的数据(过滤不匹配的数据)


5. 数组解构

很多时候你的函数可能会返回一个数组中的多个值。我们可以通过使用数组解构来轻松获取它们。

5.1 交换值

5.2 从一个函数中接收和赋值多个值

在下面的例子中,我们正在从/post上获取帖子,以及存在/comments中相关评论。由于我们使用async / await,函数返回结果保存在数组中。使用数组解构,我们可以直接将结果直接分配给相应的变量。


终端

  1. How to Jazz Up Your Terminal — A Step By Step Guide With Pictures 如何使你得终端更有趣——配图逐步指南

React性能:

  1. Two Quick Ways To Reduce React App’s Size In Production 在生产中快速减小React App大小的两种方法

  2. Using Preact Instead Of React 使用Preact代替React

函数式编程

  1. JavaScript Is Turing Complete — Explained  详解JavaScript的图灵完备性

  2. Functional Programming In JS — With Practical Examples (Part 1) JS中的函数式编程——含实例(第一部分)

  3. Functional Programming In JS — With Practical Examples (Part 2) JS中的函数式编程——含实例(第二部分)

  4. Why Redux Need Reducers To Be “Pure Functions”  为什么Redux需要Reducer以实现“虚函数”

ES6

  1. 5 JavaScript “Bad” Parts That Are Fixed In ES6 ES6中已修正的5个JavaScript糟糕部分

  2. Is “Class” In ES6 The New “Bad” Part? ES6中的Class是新的糟糕部分吗?

WebPack

  1. Webpack — The Confusing Parts Webpack——疑惑的部分

  2. Webpack & Hot Module Replacement [HMR] (under-the-hood)  WebPack及热模块替换(HMR,揭秘)

  3. Webpack’s HMR And React-Hot-Loader — The Missing Manual Webpack中HMR和React-Hot-Loader——丢失的手册

Draft.js

  1. Why Draft.js And Why You Should Contribute 为什么使用Draft.js以及为什么你需要贡献

  2. How Draft.js Represents Rich Text Data Draft.js如何表示富文本数据

React和Redux :

  1. Step by Step Guide To Building React Redux Apps 逐步构建React Redux应用指南

  2. A Guide For Building A React Redux CRUD App (3-page app) 构建一个React Redux CRUD应用指南

  3. Using Middlewares In React Redux Apps 在React Redux应用中使用中间件

  4. Adding A Robust Form Validation To React Redux Apps 向React Redux应用中添加一个稳健的表单验证机制

  5. Securing React Redux Apps With JWT Tokens 使用JWT令牌的安全React Redux应用

  6. Handling Transactional Emails In React Redux Apps 在React Redux应用中处理事务型电子邮件

  7. The Anatomy Of A React Redux App 一个React Redux应用解析

  8. Why Redux Need Reducers To Be “Pure Functions” 为什么Redux需要Reducer以实现“虚函数”

  9. Two Quick Ways To Reduce React App’s Size In Production 在生产中快速减小React App大小的两种方法


猜你喜欢

转载自blog.csdn.net/zdhsoft/article/details/79787765