简介

自从ES6(ECMAScript 2015)在2015年发布以来,ECMAScript以每年一个版本的速度持续向前发展。到现在已经是ECMAScript 2020了。

每个版本都有一些新的特性,今天本文将会讲解ES7中带来的新特性。

TC39和ECMAScript

先讲一下ECMA的历史,ECMA在于1960年4月27日成立的制造商协会,其目的是统一标准,方便在不同的制造商之间移植。于是这个协会被命名为European Computer Manufacturers Association,简称ECMA。

在1994,为了体现ECMA协会的全球性活动,改名为欧洲标准化信息和通信系统协会 European association for standardizing information and communication systems。虽然名字还保留了欧洲的字样,但是其本身已经是一个国际性协会了。

我们大概看一下ECMA协会的会员都有哪些,优先级最高的会员叫做Ordinary Members,基本上都是国际的大公司组成的:

然后次一级的叫做Associate Members:

可以看到里面有几个中国的公司,说明中国已经在世界上的规则制定方面有了一定的话语权。

TC39就是ECMA协会下属的一个专门用来指定ECMAScript标准的委员会。TC的意思是 Technical Committees。

ECMA下属的TC有很多个,而TC39专门就是负责ECMAScript的发展。

TC39下面又分为两个Task groups。分别是:

  • TC39-TG1 — General ECMAScript Language 负责ECMAScript的发展
  • TC39-TG2 — ECMAScript Internationalization API Specification 负责ECMAScript国际化API的制定

我们知道ES5是在2009年制定的,而ECMAScript 2015 (ES6)是在2015年制定的,因为ES6包含了6年的改动,所以ES6的改动非常的大。

为了减少各大厂商对ECMA脚本的升级适应压力,从ES6之后,ECMA协会决定每年发一个ECMA版本。

下面给大家讲解一下ECMAScript是怎么发布的。ECMAScript的发布主要分为下面的5个阶段:

  • Stage 0: strawman

这是自由提交的阶段,但是提交者必须是TC39 member 或者TC39 contributor。

  • Stage 1: proposal

Stage 0的strawman被TC39 review之后,就到了proposal阶段。

在这个阶段必须知道谁来负责这个proposal,同时需要提交这个提案的示例,API以及语义和算法的实现。还需要指明这个提案和现有的功能之间的可能冲突的地方。

如果这个提案被TC39接受了。那么表示TC39将会继续跟进这个提案。

  • Stage 2: draft

这个是提案的第一个版本,该提案还必须具有对该功能的语法和语义的形式化描述(使用ECMAScript规范的形式语言)。描述需要应尽可能完整,但可以包含待办事项和占位符。

  • Stage 3: candidate

这个阶段的提案已经大部分完成了,需要根据用户的反馈来进行下一步的调整。

  • Stage 4: finished

这个阶段的提案已经准备被包含在下一个ECMAScript的版本中了。

ECMAScript 2016(ES7)的新特性

实际上,ECMAScript 2016(ES7)只有两个新特性:

  • Array.prototype.includes
  • Exponentiation operator (**)

Array的新方法includes

ES7为Array添加了新的方法includes,我们看下使用的例子:

> ['a', 'b', 'c'].includes('a')
true
> ['a', 'b', 'c'].includes('d')
false

看一下includes的定义:

Array.prototype.includes(value : any) : boolean

如果value包含在Array中,那么将会返回true,如果没有包含则会返回false。

可以看到includes和indexOf比较类似:

arr.includes(x)

等价于:

arr.indexOf(x) >= 0

他们的区别在于,includes可以查找NaN,而indexOf不能:

> [NaN].includes(NaN)
true
> [NaN].indexOf(NaN)
-1

另外include是不区分+0和-0的:

> [-0].includes(+0)
true

我们知道JS中的数组除了Array之外,还有Typed Array,比如:

  • Int8Array
  • Uint8Array
  • Uint8ClampedArray
  • Int16Array
  • Uint16Array
  • Int32Array
  • Uint32Array
  • Float32Array
  • Float64Array
  • BigInt64Array
  • BigUint64Array

所以includes方法也适用于TypedArray:

let tarr = Uint8Array.of(12, 5, 3);
console.log(tarr.includes(5)); // true

幂操作符 **

ES7引入了幂操作符 ** :

> 6 ** 2
36

上面的例子表示的是6的2次方。

x ** y 的值和 Math.pow(x, y) 是等价的。

我们看下幂操作符的基本使用:

const squared = 3 ** 2; // 9

let num = 3;
num **= 2;
console.log(num); // 9 function dist(x, y) {
return Math.sqrt(x**2 + y**2);
}

幂操作符的优先级是非常高的,** > * > +

> 2**2 * 2
8
> 2 ** (2*2)
16

总结

ES7的新特性就这两个,比较简单,今天就介绍到这里。

本文作者:flydean程序那些事

本文链接:http://www.flydean.com/ecmascript-7/

本文来源:flydean的博客

欢迎关注我的公众号:「程序那些事」最通俗的解读,最深刻的干货,最简洁的教程,众多你不知道的小技巧等你来发现!

ECMAScript 2016(ES7)新特性简介的更多相关文章

  1. ECMAScript 2017(ES8)新特性简介

    目录 简介 Async函数 共享内存和原子操作 Object的新方法 String的新方法 逗号可以添加到函数的参数列表后面了 简介 ES8是ECMA协会在2017年6月发行的一个版本,因为是ECMA ...

  2. ECMAScript 2018(ES9)新特性简介

    目录 简介 异步遍历 Rest/Spread操作符和对象构建 Rest Spread 创建和拷贝对象 Spread和bject.assign() 的区别 正则表达式 promise.finally 模 ...

  3. ECMAScript 2019(ES10)新特性简介

    简介 ES10是ECMA协会在2019年6月发行的一个版本,因为是ECMAScript的第十个版本,所以也称为ES10. 今天我们讲解一下ES10的新特性. ES10引入了2大特性和4个小的特性,我们 ...

  4. ECMAScript 2020(ES11)新特性简介

    目录 简介 动态imports import.meta export加强 BigInt matchAll() globalThis Promise.allSettled() ??操作符 ?.操作符 总 ...

  5. ECMAScript 2021(ES12)新特性简介

    简介 ES12是ECMA协会在2021年6月发行的一个版本,因为是ECMAScript的第十二个版本,所以也称为ES12. ES12发行到现在已经有一个月了,那么ES12有些什么新特性和不一样的地方呢 ...

  6. SharePoint 2016 的新特性概览(二)(What's New for IT Professionals in SharePoint Server 2016)

    博客地址:http://blog.csdn.net/FoxDave SharePoint 2016 的新特性 三. 监测和数据(Insights and Data) 实时数据监测,包括对使用情况.存储 ...

  7. SharePoint 2016 的新特性概览(一)(What's New for IT Professionals in SharePoint Server 2016)

    博客地址:http://blog.csdn.net/FoxDave 今天看霖雨大神的转的微软最新的关于SharePoint 2016的Update,正好看到了SP2016新发布的视频,整理一下发出 ...

  8. ES6新特性简介

    ES6新特性简介 环境安装 npm install -g babel npm install -g babel-node //提供基于node的REPL环境 //创建 .babelrc 文件 {&qu ...

  9. ECMAScript 2016(ES7) 知多少

    ECMAScript 2016(ES7) 知多少 1. 数组方法 Array.prototype.includes(value : any) : boolean 2. 幂运算符 x ** y 扩展阅读 ...

随机推荐

  1. 前端安全 All In One

    前端安全 All In One refs xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!

  2. free open music API all in one

    free open music API all in one music API SoundCloud xgqfrms · free https://w.soundcloud.com/player/? ...

  3. Taro 框架实现原理

    Taro 框架实现原理 小程序 H5 RN Web 多端框架 Taro 1.x & Taro 2.x 编译型架构, 语法编译转换 Taro 1/2 属于编译型架构,主要通过对类 React 代 ...

  4. how to watch vuex state update

    how to watch vuex state update watch https://vuex.vuejs.org/api/#watch https://vuex.vuejs.org/guide/ ...

  5. 小程序 & taro 踩坑指南

    小程序 & taro 踩坑指南 微信开发者工具, 不支持 react bug https://github.com/NervJS/taro/issues/5042 solution just ...

  6. NGK算力持有好处多多!SPC、VAST等免费拿!

    众所周知,NGK是分布式存储的,作为Web3.0以及数字经济时代的基础设施,为数字加密市场带来了全新的商业模式和经济业态,但是,这只是一个重要的起点,真正的价值还在后面! 为了满足NGK生态建设者强烈 ...

  7. 万链互联时代,NGK DeFi项目如何在牛市中崭露头角!

    众所周知,中心化交易所存在技术风险.道德风险与法律风险.去中心化交易所像是NGK以其匿名性.安全性.私钥独立掌控的特点,弥补了中心化交易所的不足,我们看到Uniswap日成交量均超过1亿美元,甚至接近 ...

  8. django学习-2.urls.py和view.py的相关知识点

    1.URL函数简单解析 1.1.url() 函数可以接收四个参数,分别是两个必选参数:regex.view,和两个可选参数:kwargs.name. def url(regex, view, kwar ...

  9. 无法将“node.exe”项识别为 cmdlet、函数、脚本文件或可运行程序的名称

    有些天没有启动前端项目,发现npm run dev,启动不了,经过一番查找发现问题所在 然后我查看了一下报错位置,发现并没有改动过什么 解决方法: 方法一: 检查一下npm目录: 这里发现少了node ...

  10. Dubbo之高级特性

    Dubbo 注意当启动服务时,该服务会占用本机一个端口号,故在一台电脑启动多个服务时需要在配置文件中更占用本机的端口号 <!--服务占用本机的端口-当本机启动多个服务时须保持不同--> & ...