ECMAScript标准制定过程展示及ES7新特性披露
liuian 2025-06-09 23:33 24 浏览
2015年6正式发布的ES6是ECMAScript的最新版本,它的发布具有里程碑意义,不仅带来了众多的新特性, 而且自此将改变ECMAScript的发布策略。本文将会介绍ECMAScript标准的最新制定过程, 并简要的介绍将会出现在ECMASCript 2016中的主要新特性。
基础知识
ES6作为ECMAScript的最新版本,在ES6发布的近6年后才被正式标准化(2009年12月 vs 2015年6月)。 导致这么长跨度的主要原因有两个:
- 所有的特性无论先后,都必须等待新的发行版本(release)完全制定完成后才能公布;
- 有些特性未能完全达成一致,从而造成了整个发行版本的延迟。如果这些特性推迟到下一个发行版本,那么将会耗费更多的时间。
为了避免这种缓慢的发行版本更新策略,从ECMAScript 2016(ES7)开始,版本的发布将会变得更加频繁, 这也意味着未来每个新的发行版本都会包含尽可能少的特性,而发行周期则缩短为1年,并且每年只发行确保一年期限内能够完成的所有特性。 为了向你简要的介绍新的版本发行策略,首先需要介绍的是TC39。
技术委员会39 (Technical Committee 39 - TC39)
TC39(ECMA技术委员为39)是推动JavaScript发展的委员会。 它的成员都是企业(主要是浏览器厂商)。TC39会定期的开会, 会议的主要成员是成员公司的代表,以及受邀请的专家。 你可以参考网络上的一个有关TC39会议的会议纪要来了解TC39是如何工作。
在本文中,通常我们用“TC39成员”这个术语来指代一个具体的人,他是由TC39成员公司所委派的会议代表。 有一点值得注意的是,TC39必须达成全员一致的协议:决策只有被所有的成员单位一致同意时才能被做出。
TC39的过程
针对ECMAScript特性的每一个提议都需要经历以下几个成熟阶段,从阶段0开始。从一个阶段递交到下一个阶段必须要收到TC39的全员同意。
Stage 0:strawman 稻草人
在该阶段可以自由的使用任意方式提交推动ECMAScript发展的想法。提议可以来自TC39成员单位,也可以是一个非成员单位, 但需要注册成为了TC39的贡献者。
条件:文档必须要在TC39会议上进行审核,然后将会被添加阶段0的建议页面中。
Stage 1:Proposal 提议
阶段1是对所提交特性的正式建议。
条件:必须要指派具体的人来负责该提议。该负责人或助理负责人必须是TC39的成员。该提议所解决的问题必须通过描述性的文档进行说明。 解决方法必须有例子、API,以及对语义和算法的讨论。最后,存在的潜在问题也必须要得到区分,例如与其他特性之间的关联,以及实现的难度。 Implementation-wise,polyfills和demos也都是必须的。
下一步:对于阶段1的提议的是否接受,TC39表明了其愿意检查、讨论和为提议做出贡献。继续向前,将会是提议的主要变化。
Stage 2:Draft 草案
阶段2是将会出现标准中的第一个版本。此时,将会与出现在标准中的最终特性是差不多的。
条件:此时建议必须要附加更规范化有关特性的语法和语意的说明(使用ECMAScript标准的正式语言)。 描述应该尽可能的完整,但也可以包含待办事项列表和占位符。该特性需要两个实验性的实现, 但其中一个可以在诸如Babel这样的转译器(transpiler)中。
下一步:从该改阶段只接收渐增的变化。
Stage 3:Canidate 候选
此时提议已经接近完成,只需要得到提议实现方的反馈,以及由用户来进一步推动。
条件:标准的文本必须是完备的。指定的审稿人(由TC39指派)和ECMAScript标准的编辑必须在该标准上签字。 必须要至少有两个符合标准的实现(可以不指定默认实现)。
下一步:至此之后,只有对实现和使用过程中出现的重大问题进行修正。
Stage 4:Finished 完成
提议将被包括到标准之中。
条件:在提议进入该阶段时需要满足以下的条件:
- Test 262验收测试(主要是用JavaScript代码编写的单元测试来验证语言特性);
- 两个通过测试的符合规范的装运实现(shipping implementations);
- 使用该实现的重要的实践经验;
- ECMAScript标准的编辑必须要签署该标准的文本;
下一步:该提议会被尽可能快的纳入到ECMAScript标准中。当标准通过长达一年的时间获得通过后,该提议将正式作为标准的其一部分。
不要称它们为ECMAScript 20xx特性
正如你看到的那样,只有到了阶段4,该特性才会被确定加入到标准中。然后会在下一次的ECMAScript发布中出现该提议, 当然也并非是百分百的,也可能需要更长的时间。因此,你不应该称提议为“ES7特性”或者“ES2016特性”等等。我通常喜欢的称法如下:
- ECMAScript建议:某特性。该建议所处的阶段应该在文章的一开始就被说明。
- ES.stage2: 某特性。
如果该提议几经进入阶段4,那么我会称他为ES20XX特性,当然最安全的做法是等到标准的编辑已经确认该下一个发布会包含该特性后才行。 例如Object.observe就是ECMAScript提议被进展到阶段2,却又最终被撤回的个例子。
ECMAScript Stage 3提议
下面这4个特性可能会出现在ECMAScript 2016中。
1. 指数操作符
该提议建议使用**操作符作为中缀来实现指数操作:
x ** y
产生的结果等同于
Math.pow(x, y)
例如:
let squared = 3 ** 2; // 9 let num = 3; num **= 2; console.log(num); // 9
进一步阅读可以参考:
2. Array.prototype.include
数组方法includes有以下的签名:
Array.prototype.includes(value : any) : boolean
如果value值是当前接收者(this)的元素的话则返回true,否则返回false:
> ['a', 'b', 'c'].includes('a'); ture > ['a', 'b', 'c'].includes('d'); false
includes与indexof类似——下面两个表达式几乎是相等的:
arr.includes(x) arr.indexOf(x) >= 0
唯一的区别是includes能发现NaN,而indexof不能:
> [NaN].includes(NaN) true > [NaN].indexOf(NaN) -1
includes并不会区分+0和-0(这也是JavaScript所一直表现的):
> [-0].includes(+0) true
有类型的数组也可以使用includes方法:
let tarr = Unit8Array.of(12, 5, 3); console.log(tarr.includes(5)); // true
常被问到的问题:
后者是最初的选择,但是对于Web而言会存在问题(MooTools向Array.prototype中增加了这个方法)
has用于键(Map.ptototype.has),includes用于元素(String.prototype.includes)。Set中的元素既可以看作是键和值, 这就是为什么在Set中有一个Set.prototype.has,而没有includes。
- ES6的方法String.prototype.includes用于字符串,而不是字符。这是否和Array.prototype.includes不一致?
如何数组的includes和字符串的includes工作模式一样的话,他将接收数组,而不是单个元素。但这两个includes都参照了indexof的例子, 字符可以看作为特殊的场景,而有固定长度的字符串则是更常见的场景。
进一步阅读:
3. SIMD.JS - SIMD APIs + Polyfill
SIMD代表的是“single instruction, multiple data(单指令多数据)”的意思,是CPU有能力将一个操作数应用于值向量(而不是单个值)。 SIMD指令集的一个流行的例子是SSE(Streaming SIMD Extensions),在被Intel处理器所支持。下面是一个简单的例子:
var a = SIMD.float32x4(1.0, 2.0, 3.0, 4.0); var b = SIMD.float32x4(5.0, 6.0, 7.0, 8.0); var c = SIMD.float32x4.add(a, b);
进一步阅读:
4. 异步函数
在这之前,如果我要介绍异步函数的话,肯定要解释如何使用Promise和生成器来使用类似于同步的代码执行异步操作。
使用Promise和生成器来编写异步代码:
对于那些需要异步的计算它们的一次性结果的函数而言,作为ES6一部分的Promise,正在变得越来越流行。 其中一个例子就是客户端的fetchAPI,它被设计用来取代XMLHttpRequest来获取文件。 它的使用代码大致如下:
function fetchJson(url) { return fetch(url) .then(request => request.next) .then(text => { return JSON.parse(text); }) .catch(error => { console.log(`ERROR: ${error.statck}`); }); } fetchJson('http://example.com/some_file.json') .then(obj => console.log(obj));
co是一个使用Promise和生成器来允许代码风格看起来更同步的库,但也需要使用类似于前面的例子那样的风格去编码:
const fetchJson = co(function * { try { let request = yield fetch(url); let text = yield request.text; return JSON.parse(text); } catch (error) { console.log(`ERROR: ${error.statck}`); } });
每次回调函数(一个生成器函数)会向co产生一个Promise,回调函数被挂起。一旦Promise被安置好,co便恢复回调函数: 如果Promise被满足,yield便返回满足的值,如果被拒绝,yield便抛出异常。此外,co能够promise化回调函数所返回的结果。
异步函数
异步函数是执行类似co行为的专用语法:
async funtion fetchJson(url) { try { let request = await fetch(url); let text = await request.text; return JSON.parse(text); } catch(error) { console.log(`ERROR: ${error.statck}`); } }
在内部,异步函数的工作非常类似于生成器,但它并不会被翻译为生成器代码:
变种
存在如下一些生成器函数的变种:
- 异步函数声明: async function foo { }
- 异步函数表达式:const foo = async function {};
- 异步方法定义:let obj = { async foo {} }
- 异步箭头函数:const foo = async => {}
进一步阅读
阅读材料
你可以阅读以下材料来深入的理解本文中涉及到的内容:
Github:ecma262,它包括:
TC39进度文档
其他阅读材料:
译者简介:景庄,前端工程师,关注Node.js、前端工程化。个人博客:http://wwsun.github.com。
相关推荐
- 总结下SpringData JPA 的常用语法
-
SpringDataJPA常用有两种写法,一个是用Jpa自带方法进行CRUD,适合简单查询场景、例如查询全部数据、根据某个字段查询,根据某字段排序等等。另一种是使用注解方式,@Query、@Modi...
- 解决JPA在多线程中事务无法生效的问题
-
在使用SpringBoot2.x和JPA的过程中,如果在多线程环境下发现查询方法(如@Query或findAll)以及事务(如@Transactional)无法生效,通常是由于S...
- PostgreSQL系列(一):数据类型和基本类型转换
-
自从厂子里出来后,数据库的主力就从Oracle变成MySQL了。有一说一哈,贵确实是有贵的道理,不是开源能比的。后面的工作里面基本上就是主MySQL,辅MongoDB、ES等NoSQL。最近想写一点跟...
- 基于MCP实现text2sql
-
目的:基于MCP实现text2sql能力参考:https://blog.csdn.net/hacker_Lees/article/details/146426392服务端#选用开源的MySQLMCP...
- ORACLE 错误代码及解决办法
-
ORA-00001:违反唯一约束条件(.)错误说明:当在唯一索引所对应的列上键入重复值时,会触发此异常。ORA-00017:请求会话以设置跟踪事件ORA-00018:超出最大会话数ORA-00...
- 从 SQLite 到 DuckDB:查询快 5 倍,存储减少 80%
-
作者丨Trace译者丨明知山策划丨李冬梅Trace从一开始就使用SQLite将所有数据存储在用户设备上。这是一个非常不错的选择——SQLite高度可靠,并且多种编程语言都提供了广泛支持...
- 010:通过 MCP PostgreSQL 安全访问数据
-
项目简介提供对PostgreSQL数据库的只读访问功能。该服务器允许大型语言模型(LLMs)检查数据库的模式结构,并执行只读查询操作。核心功能提供对PostgreSQL数据库的只读访问允许L...
- 发现了一个好用且免费的SQL数据库工具(DBeaver)
-
缘起最近Ai不是大火么,想着自己也弄一些开源的框架来捣腾一下。手上用着Mac,但Mac都没有显卡的,对于学习Ai训练模型不方便,所以最近新购入了一台4090的拯救者,打算用来好好学习一下Ai(呸,以上...
- 微软发布.NET 10首个预览版:JIT编译器再进化、跨平台开发更流畅
-
IT之家2月26日消息,微软.NET团队昨日(2月25日)发布博文,宣布推出.NET10首个预览版更新,重点改进.NETRuntime、SDK、libraries、C#、AS...
- 数据库管理工具Navicat Premium最新版发布啦
-
管理多个数据库要么需要使用多个客户端应用程序,要么找到一个可以容纳你使用的所有数据库的应用程序。其中一个工具是NavicatPremium。它不仅支持大多数主要的数据库管理系统(DBMS),而且它...
- 50+AI新品齐发,微软Build放大招:拥抱Agent胜算几何?
-
北京时间5月20日凌晨,如果你打开微软Build2025开发者大会的直播,最先吸引你的可能不是一场原本属于AI和开发者的技术盛会,而是开场不久后的尴尬一幕:一边是几位微软员工在台下大...
- 揭秘:一条SQL语句的执行过程是怎么样的?
-
数据库系统能够接受SQL语句,并返回数据查询的结果,或者对数据库中的数据进行修改,可以说几乎每个程序员都使用过它。而MySQL又是目前使用最广泛的数据库。所以,解析一下MySQL编译并执行...
- 各家sql工具,都闹过哪些乐子?
-
相信这些sql工具,大家都不陌生吧,它们在业内绝对算得上第一梯队的产品了,但是你知道,他们都闹过什么乐子吗?首先登场的是Navicat,这款强大的数据库管理工具,曾经让一位程序员朋友“火”了一把。Na...
- 详解PG数据库管理工具--pgadmin工具、安装部署及相关功能
-
概述今天主要介绍一下PG数据库管理工具--pgadmin,一起来看看吧~一、介绍pgAdmin4是一款为PostgreSQL设计的可靠和全面的数据库设计和管理软件,它允许连接到特定的数据库,创建表和...
- Enpass for Mac(跨平台密码管理软件)
-
还在寻找密码管理软件吗?密码管理软件有很多,但是综合素质相当优秀且完全免费的密码管理软件却并不常见,EnpassMac版是一款免费跨平台密码管理软件,可以通过这款软件高效安全的保护密码文件,而且可以...
- 一周热门
-
-
Python实现人事自动打卡,再也不会被批评
-
【验证码逆向专栏】vaptcha 手势验证码逆向分析
-
Psutil + Flask + Pyecharts + Bootstrap 开发动态可视化系统监控
-
一个解决支持HTML/CSS/JS网页转PDF(高质量)的终极解决方案
-
再见Swagger UI 国人开源了一款超好用的 API 文档生成框架,真香
-
网页转成pdf文件的经验分享 网页转成pdf文件的经验分享怎么弄
-
C++ std::vector 简介
-
飞牛OS入门安装遇到问题,如何解决?
-
系统C盘清理:微信PC端文件清理,扩大C盘可用空间步骤
-
10款高性能NAS丨双十一必看,轻松搞定虚拟机、Docker、软路由
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)