聊聊ES7与ES8特性
译者按: 转眼ES6发布2年了,是时候了解一下ES7与ES8特性了!
- 译者: Fundebug 
为了保证可读性,本文采用意译而非直译,并且对源代码进行了大量修改。另外,本文版权归原作者所有,翻译仅用于学习。
我曾写过一篇关于ES6博客《10个最佳ES6特性》,这次我打算聊聊ES7和ES8特性。
ES7只有2个特性:
- includes()
- 指数操作符
ES8尚未发布(2017年1月),下面是它已经完成起草的一些特性:
- Object.values()
- Object.entries()
- padStart()
- padEnd()
- Object.getOwnPropertyDescriptors()
- 函数参数列表结尾允许逗号
- Async/Await
Array.prototype.includes()
不使用ES7
使用indexOf()验证数组中是否存在某个元素,这时需要根据返回值是否为-1来判断:
| let arr = ['react', 'angular', 'vue']; if (arr.indexOf('react') !== -1) { console.log('React存在'); } | 
使用ES7
使用includes()验证数组中是否存在某个元素,这样更加直观简单:
| let arr = ['react', 'angular', 'vue']; if (arr.includes('react')) { console.log('React存在'); } | 
指数操作符
不使用ES7
使用自定义的递归函数calculateExponent或者Math.pow()进行指数运算:
| function calculateExponent(base, exponent) { if (exponent === 1) { return base; } else { return base * calculateExponent(base, exponent - 1); } } console.log(calculateExponent(7, 3)); // 输出343 console.log(Math.pow(7, 3)); // 输出343 | 
使用ES7
使用指数运算符**,就像+、-等操作符一样:
| console.log(7**3); | 
Object.values()
不使用ES8
使用Object.keys()遍历对象的属性值,需要通过属性名key去获取属性值:
| let obj = {a: 1, b: 2, c: 3}; Object.keys(obj).forEach((key) => { console.log(obj[key]); // 输出1, 2, 3 }); | 
使用ES8
使用Object.values()遍历对象的属性值,无需使用使用属性名:
| let obj = {a: 1, b: 2, c: 3} Object.keys(obj).forEach((key) => { console.log(obj[key]); // 输出1, 2, 3 }); | 
Object.entries()
不使用ES8
使用Object.keys()遍历对象的属性名和属性值:
| let obj = {a: 1, b: 2, c: 3}; Object.keys(obj).forEach((key) => { console.log(key + ": " + obj[key]); // 输出a: 1, b: 2, c: 3 }) | 
使用ES8
使用Object.entries()遍历对象的属性名和属性值:
| let obj = {a: 1, b: 2, c: 3}; Object.entries(obj).forEach(([key, value]) => { console.log(key + ": " + value); // 输出a: 1, b: 2, c: 3 }) | 
padStart()
不使用ES8
| console.log('0.00')  console.log('10,000.00')  console.log('250,000.00') | 
输出结果如下:
| 0.00 10,000.00 250,000.00 | 
使用ES8
使用padStart()可以在字符串前面填充指定的字符串:
| console.log('0.00'.padStart(20))  console.log('10,000.00'.padStart(20))  console.log('250,000.00'.padStart(20)) | 
输出结果如下:
| 0.00 10,000.00 250,000.00 | 
padEnd()
不使用ES8
| console.log('0.00 ' + '0.00' )  console.log('10,000.00 ' + '10,000.00' )  console.log('250,000.00 ' + '250,000.00') | 
输出如下:
| 0.00 0.00 10,000.00 10,000.00 250,000.00 250,000.00 | 
使用ES8
使用padEnd()可以在字符串后面填充指定的字符串:
| console.log('0.00'.padEnd(20) + '0.00' )  console.log('10,000.00'.padEnd(20) + '10,000.00' )  console.log('250,000.00'.padEnd(20) + '250,000.00') | 
输出如下:
| 0.00 0.00 10,000.00 10,000.00 250,000.00 250,000.00 | 
Object.getOwnPropertyDescriptors()
azatsBooks对象的定义如下:
| let azatsBooks = { books: ['React Quickly'], get latest() { let numberOfBooks = this.books.length; if (numberOfBooks == 0) return undefined; return this.books[numberOfBooks - 1]; } }; | 
不使用ES8
使用Object.getOwnPropertyDescriptor()获取单个属性的属性描述符。
获取azatsBooks对象的books属性的属性描述符:
| console.log(Object.getOwnPropertyDescriptor(azatsBooks, 'books')); /** 输出books属性的属性描述 [object Object] {  configurable: true,  enumerable: true,  value: ["React Quickly"],  writable: true } **/ | 
获取azatsBooks对象的lastest方法的属性描述符:
| console.log(Object.getOwnPropertyDescriptor(azatsBooks, 'latest')); /** 输出lastest方法的属性描述 [object Object] {  configurable: true,  enumerable: true,  get: function get latest() {  let numberOfBooks = this.books.length  if (numberOfBooks == 0) return undefined  return this.books[numberOfBooks - 1]  },  set: undefined } **/ | 
使用ES8
Object.getOwnPropertyDescriptors()相当于Object.getOwnPropertyDescriptor()的复数形式,可以获取对象的所有自身属性的描述符:
| console.log(Object.getOwnPropertyDescriptors(azatsBooks)) /** 输出azatsBooks对象所有自身属性的属性描述 [object Object] {  books: [object Object] {  configurable: true,  enumerable: true,  value: ["React Quickly"],  writable: true  },  latest: [object Object] {  configurable: true,  enumerable: true,  get: function get latest() {  let numberOfBooks = this.books.length  if (numberOfBooks == 0) return undefined  return this.books[numberOfBooks - 1]  },  set: undefined  } } **/ | 
函数参数列表结尾允许逗号
不使用ES8
| var f = function(a,  b,  c,  d // d之后不能带逗号  ) {  console.log(d) } | 
使用ES8
| var f = function(a,  b,  c,  d, // d之后允许带逗号 ) {  console.log(d) } | 
允许逗号之后,可以避免一些不必要的报错。(如果你希望实时监控JavaScript应用的错误,欢迎免费使用Fundebug)
Async/Await
使用Promise
使用Promise写异步代码,会比较麻烦:
| axios.get(`/q?query=${query}`) .then(response => response.data) .then(data => { this.props.processfetchedData(data); }) .catch(error => console.log(error)); | 
使用Async/Await
Async/Await使得异步代码看起来像同步代码,这正是它的魔力所在:
| async fetchData(query) => { try { const response = await axios.get(`/q?query=${query}`); const data = response.data; return data; } catch (error) { console.log(error) } } fetchData(query).then(data => { this.props.processfetchedData(data) }) | 
Async/Await是写异步代码的新方式,以前的方法有回调函数和Promise。相比于Promise,它更加简洁,并且处理错误、条件语句、中间值都更加方便,因此有望替代Promise,成为新一代的一步代码编写方式。对细节感兴趣的话,可以查看Fundebug翻译的《Async/Await替代Promise的6个理由》。
关于Fundebug:
Fundebug专注于JavaScript、微信小程序、微信小游戏、支付宝小程序、React Native、Node.js和Java实时BUG监控。 自从2016年双十一正式上线,Fundebug累计处理了7亿+错误事件,得到了Google、360、金山软件、百姓网等众多知名用户的认可。欢迎免费试用! 
版权声明:
转载时请注明作者Fundebug以及本文地址:
https://blog.fundebug.com/2017/08/28/es7-and-es8/
聊聊ES7与ES8特性的更多相关文章
- ES7 and ES8 特性
		ES7 特性:1.Array.prototype.includes let arr = ['react', 'angular', 'vue'] // Correct if (arr.includes( ... 
- ES7的新特性
		ES7的新特性 ES7 特性: 1.Array.prototype.includes2.Exponentiation Operator(求幂运算) 一,Array.prototype.includes ... 
- ES6,ES7,ES8 常用特性总结
		一. ES6(ES2015) 1. 变量 let 和常量 const var 的问题 可以重复声明,没有报错和警告 无法限制修改 没有块级作用域, { } let 和 const 不能重复声明 都是块 ... 
- ES6、ES7、ES8、ES9、ES10新特性
		ES6新特性(2015) ES6的特性比较多,在 ES5 发布近 6 年(2009-11 至 2015-6)之后才将其标准化.两个发布版本之间时间跨度很大,所以ES6中的特性比较多. 在这里列举几个常 ... 
- ES7/8新特性学习随笔
		随着每年EcmaScript都会为js带来一些新特性,带来更多美化的编程体验,今天就走进一下es2016/2017所带来的新特性 ES7新特性 includes() 指数操作符 ES8新特性 asyn ... 
- ES6、ES7、ES8、ES9、ES10
		ES6新特性(2015) ES6的特性比较多,在 ES5 发布近 6 年(2009-11 至 2015-6)之后才将其标准化.两个发布版本之间时间跨度很大,所以ES6中的特性比较多.在这里列举几个常用 ... 
- ES6,ES7,ES8 常用
		ES6常用新特性 let && const let 命令也用于变量声明,但是作用域为局部 { let a = 10; var b = 1; } 在函数外部可以获取到b,获取不到a,因此 ... 
- ES6、ES7、ES8
		ES6 https://es6.ruanyifeng.com/ ES7 1.Array.prototype.includes() includes()作用,是查找一个值在不在数组里,若是存在则返回 ... 
- 谈谈 ES7、ES8、ES9 和 Stage 3 的那些事儿
		ES6 作为多年来 JavaScript 的重大版本变革,受到 JavaScript 开发者们的普遍欢迎. 也正是从 ES6 (ES2015) 开始,JavaScript 版本发布变为年更,即每年发布 ... 
随机推荐
- KVM虚拟机配置笔记
			KVM 全称是 Kernel-Based Virtual Machine.也就是说 KVM 是基于 Linux 内核实现的,KVM有一个内核模块叫 kvm.ko,只用于管理虚拟 CPU 和内存. 在 ... 
- 《http权威指南》读书笔记9
			概述 最近对http很感兴趣,于是开始看<http权威指南>.别人都说这本书有点老了,而且内容太多.我个人觉得这本书写的太好了,非常长知识,让你知道关于http的很多概念,不仅告诉你怎么做 ... 
- 什么 是JavaScript中的变量? 部分2
			变量:是计算机存储数据的标识符 js中存储数据的方式 都是使用变量 js 中声明变量的方式都是var 存储数据,应该有对应的数据类型js中的字符串类型都用成对的单引号或者双引号包裹起来 变量 1. 变 ... 
- 树莓派MQTT客户端搭建
			树莓派安装和实现MQTT协议 下载Mosquitto 更新软件源:sudo apt-get update 下载g++编译器:sudo apt-get install g++ 安装:sudo apt- ... 
- vue项目中主要文件的加载顺序(index.html、App.vue、main.js)
			先后顺序: index.html > App.vue的export外的js代码 > main.js > App.vue的export里面的js代码 > Index.vue的ex ... 
- preg_replace的一些细节
			.$pattern是数组,$replace也是数组,则中对应的 元素进行替换 php preg_replace有五个参数,有三个是必须参数 Preg_replace(mixed $pattern, m ... 
- elasticsearch 操作
			文档:https://www.elastic.co/guide/en/elasticsearch/reference/current/index.html 客户端:https://www.elasti ... 
- python自动化工具之pywinauto(一个实例)结合pyuserinput
			以下是pywinauto使用指南.这个窗口句柄可以在Spy++中查看 (Microsoft Spy++(查看窗口句柄) 10.00.30319 官方最新绿色版) python自动化工具之pywinau ... 
- java字符流操作flush()方法及其注意事项
			java字符流操作flush()方法及其注意事项 flush()方法介绍 查阅文档可以发现,IO流中每一个类都实现了Closeable接口,它们进行资源操作之后都需要执行close()方法将流关闭 ... 
- Log4Net在MVC下的配置以及运用线程队列记录异常信息
			Log4Net是用来记录日志的,可以将程序运行过程中的信息输出到一些地方(文件.数据库.EventLog等),日志就是程序的黑匣子,可以通过日志查看系统的运行过程,从而发现系统的问题.日志的作用:将运 ... 
