ECMAScript标准制定过程展示及ES7新特性披露
liuian 2025-06-09 23:33 39 浏览
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。
相关推荐
- 教你把多个视频合并成一个视频的方法
-
一.情况介绍当你有一个m3u8文件和一个目录,目录中有连续的视频片段,这些片段可以连成一段完整的视频。m3u8文件打开后像这样:m3u8文件,可以理解为播放列表,里面是播放视频片段的顺序。视频片段像这...
- 零代码编程:用kimichat合并一个文件夹下的多个文件
-
一个文件夹里面有很多个srt字幕文件,如何借助kimichat来自动批量合并呢?在kimichat对话框中输入提示词:你是一个Python编程专家,完成如下的编程任务:这个文件夹:D:\downloa...
- Java APT_java APT 生成代码
-
JavaAPT(AnnotationProcessingTool)是一种在Java编译阶段处理注解的工具。APT会在编译阶段扫描源代码中的注解,并根据这些注解生成代码、资源文件或其他输出,...
- Unit Runtime:一键运行 AI 生成的代码,或许将成为你的复制 + 粘贴神器
-
在我们构建了UnitMesh架构之后,以及对应的demo之后,便着手于实现UnitMesh架构。于是,我们就继续开始UnitRuntime,以用于直接运行AI生成的代码。PS:...
- 挣脱臃肿的枷锁:为什么说Vert.x是Java开发者手中的一柄利剑?
-
如果你是一名Java开发者,那么你的职业生涯几乎无法避开Spring。它如同一位德高望重的老国王,统治着企业级应用开发的大片疆土。SpringBoot的约定大于配置、SpringCloud的微服务...
- 五年后,谷歌还在全力以赴发展 Kotlin
-
作者|FredericLardinois译者|Sambodhi策划|Tina自2017年谷歌I/O全球开发者大会上,谷歌首次宣布将Kotlin(JetBrains开发的Ja...
- kotlin和java开发哪个好,优缺点对比
-
Kotlin和Java都是常见的编程语言,它们有各自的优缺点。Kotlin的优点:简洁:Kotlin程序相对于Java程序更简洁,可以减少代码量。安全:Kotlin在类型系统和空值安全...
- 移动端架构模式全景解析:从MVC到MVVM,如何选择最佳设计方案?
-
掌握不同架构模式的精髓,是构建可维护、可测试且高效移动应用的关键。在移动应用开发中,选择合适的软件架构模式对项目的可维护性、可测试性和团队协作效率至关重要。随着应用复杂度的增加,一个良好的架构能够帮助...
- 颜值非常高的XShell替代工具Termora,不一样的使用体验!
-
Termora是一款面向开发者和运维人员的跨平台SSH终端与文件管理工具,支持Windows、macOS及Linux系统,通过一体化界面简化远程服务器管理流程。其核心定位是解决多平台环境下远程连接、文...
- 预处理的底层原理和预处理编译运行异常的解决方案
-
若文章对您有帮助,欢迎关注程序员小迷。助您在编程路上越走越好![Mac-10.7.1LionIntel-based]Q:预处理到底干了什么事情?A:预处理,顾名思义,预先做的处理。源代码中...
- 为“架构”再建个模:如何用代码描述软件架构?
-
在架构治理平台ArchGuard中,为了实现对架构的治理,我们需要代码+模型描述所要处理的内容和数据。所以,在ArchGuard中,我们有了代码的模型、依赖的模型、变更的模型等,剩下的两个...
- 深度解析:Google Gemma 3n —— 移动优先的轻量多模态大模型
-
2025年6月,Google正式发布了Gemma3n,这是一款能够在2GB内存环境下运行的轻量级多模态大模型。它延续了Gemma家族的开源基因,同时在架构设计上大幅优化,目标是让...
- 比分网开发技术栈与功能详解_比分网有哪些
-
一、核心功能模块一个基本的比分网通常包含以下模块:首页/总览实时比分看板:滚动展示所有正在进行的比赛,包含比分、比赛时间、红黄牌等关键信息。热门赛事/焦点战:突出显示重要的、关注度高的比赛。赛事导航...
- 设计模式之-生成器_一键生成设计
-
一、【概念定义】——“分步构建复杂对象,隐藏创建细节”生成器模式(BuilderPattern):一种“分步构建型”创建型设计模式,它将一个复杂对象的构建与其表示分离,使得同样的构建过程可以创建...
- 构建第一个 Kotlin Android 应用_kotlin简介
-
第一步:安装AndroidStudio(推荐IDE)AndroidStudio是官方推荐的Android开发集成开发环境(IDE),内置对Kotlin的完整支持。1.下载And...
- 一周热门
-
-
【验证码逆向专栏】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使用fitz模块提取pdf中的图片
-
- 最近发表
- 标签列表
-
- 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)