一.特性概览
ES2016(也就是ES7)发布于2016年6月,仅包含2个新特性:
一个数组包含性检测方法,一个幂运算符。没了,ES2016就这两个新特性,还都是锦上添花的东西
P.S.更多过审特性,见Finished Proposals
二.Array.prototype.includes
数组的includes
方法,具体如下:
// 返回true | false,表示包含不包含
// 可选参数fromIndex表示从该index开始找
// 默认是0,负数表示倒数第几个(array.length + fromIndex)
array.includes(item, [fromIndex])
用来确定数组中是否包含指定元素,类似于(但不等价):
array.indexOf(item) !== -1
二者之间存在细微的差异:
NaN:
[NaN].includes(NaN) === true
而[NaN].indexOf(NaN) === -1
稀疏数组:
[1, , 3].includes(undefined) === true
而[1, , 3].indexOf(undefined) === -1
简言之,includes
能够处理NaN
,并且不会跳过稀疏数组中的空位(也就是说不判断数组中的元素是否存在)
具体的,includes
比较相等性时采用SameValueZero算法:
对象仅比较引用
基本值比较类型和值
值比较中存在2个特例,
+0
与-0
相等,NaN
与NaN
相等
三.Exponentiation operator
幂运算符,具体如下:
// 底数 ** 指数
base ** exponent
另外,还提供了**=
:
let n = 2;
// 运算并赋值
n **= 4;
n; // => 16
完全等价于Math.pow(base, exponent)
,包括这些特殊case:
NaN ** 0; // => 1
Infinity ** 0; // => 1
-5 ** NaN; // => NaN
NaN ** NaN; // => NaN
没错,完全等价,因为毕竟幂运算是无法重新定义的(若不一致会引发混乱)
四.为什么这一版这么小?
与ES发版流程有关,ES新特性提议分为5个阶段:
stage 0(Strawman):初稿(比Draft更草一些)
stage 1(Proposal):提议
stage 2(Draft):草案
stage 3(Candidate):候选提议
stage 4(Finished):过审提议
特性提议随时可以提,多线并行审核推进,但发版周期是固定的:
2月1日:产出候选草案(Candidate Draft)
2-3月:60天的修订筛选期(royalty-free opt-out period)
3月TC39会议:合入stage 4(过审的)提议,校准最终语义,并从主分支迁出新规范版本,之后只接受编辑更改
4-6月:ECMA CC与ECMA GA审核期
7月:由ECMA大会(ECMA General Assembly)批准新标准
每年7月发版,把新过审的特性提议带上去,所以一个版本包含的新特性数量取决于这一年有多少特性过审了
这样一方面能够保证规范发布的特性都经过广泛审核确认了,另一方面保持每年一版的频繁节奏,避免再出现ES2015那样的大版本(6年憋一版)
P.S.关于Ecma TC39的ES发版流程的更多信息,见The TC39 Process