共计 4586 个字符,预计需要花费 12 分钟才能阅读完成。
观感度:????????????????????
口味:秘制烤板筋
烹饪工夫:15min
本文已收录在前端食堂同名仓库 Github github.com/Geekhyt,欢迎光临食堂,如果感觉酒菜还算可口,赏个 Star 对食堂老板来说是莫大的激励。
本文记录并整顿了 D2 前端技术论坛中揭秘 TC39: ES2020 和 ES2021
的会议笔记。(截取了 TC39 局部)分享给没工夫看或是对 TC39 还不理解的同学们。
揭秘 TC39: ES2020 和 ES2021
分享嘉宾:Ujjwal Sharma
TC39 成员、Node.js 外围协作者。
TC39
TC39 是 Ecma International 标准化组织旗下的技术委员会的一员,它负责管理着 ECMAScript 语言和标准化 API。
ECMAScript 语言和标准化 API 又能够分为两个规范:
- 第一个是 ECMA-262 规范,它蕴含了语言的语法和外围的 API。
- 另一个规范 ECMA-402 则蕴含了一些国际化的 API,提供给 ECMAScript 外围 API 选择性反对。
Who?
Delegates
implementers
Large websites
Academics
OpenJS Foundation
Invited Experts
Subject matter exports
Community representatives
Contributors
Community
TC39 包含会议代表们,可能是执行者、大型的网站、学术研究者以及 OpenJS 基金会。
同时也会邀请一些主题内容的专家来提供帮忙,也会邀请一些社区代表,比方 Babel 和 nodejs 社区。另外还有一些突出贡献者,对某一议题有非凡奉献的人。最初,也包含整个社区,人们的各种反应和奇思妙想对 TC39 的每个决定都十分有帮忙。
What?
Pull request to the standard GitHub repository
Meta and Markup changes
Editorial Changes
Editor Group
Normative Changes
Proposals
Authors and Champions
Stage Process
Reviewers
Consensus
想要批改 JavaScript 标准规范,须要通过一些前置流程。
一些比拟小的变更(构建流程、CI 测试文件) -> 编辑上的扭转(设计排版),有专门的编辑者小组进行评审 -> 面向社区解说,须要证实其成果 -> 久远的重大变更,须要进行提案 -> 提案有作者们和支持者们,须要严格依照 Stage 流程进行 -> TC39 官网指定代表,对提案进行评审,提案须要答复评审中的问题 -> 整个社区达成统一,批准提案。
When?
Quarterly meetings
4-day
in-person
Light meetings in between
2-day
online
Monthly ECMA-402 meeting
Smaller,more focussed meetings
Incubator calls
GitHub
Discourse
一个季度 (每 3 个月) 有一次会议,一年有 4 次,为期 4 天的现场会议,往年因为疫情在线上举办。在季度会议之间会安顿一些小型会议,始终采纳在线模式为期 2 天。
除此之外,还有月度 ECMA-402 会议,作为另外一项独立的标准规范,它蕴含很多国际化的相干内容。
还会有一些更小、更聚焦的会议,例如 ECMAScript 平安的会议和钻研相干主题的会议。
(Incubator calls) 孵化招集,用来探讨一些特定的提案。
最初还有 GitHub 和论坛,GitHub 是实现大部分开发和决定的中央,论坛则是提案更晚期探讨发动的中央。
How?
No voting
Consensus-based decision making
Diverse set of people in the committee
Work to satisfy everyone‘s needs and goals
Objections and concerns
Backing rationales
No stakeholder kept over another
Don't standardize things which aren't ready
没有投票,目标是为了达成统一。
委员会由多样化的人组成,代表了不同的利益群体。TC39 委员会的工作就是要满足大家的需要和指标。
大家都有不同的需要,也会有异议和意见,但终极目标是为了解决问题,达成统一,而不是用投票来满足大部分人的需要。
最好的中央在于没有利益方互相阻塞。
还有一个重要准则:事件如果没有筹备好就不会将规范落地。
TC39 Stage Process (TC39 的 Stage 阶段过程)
Stage 0: Strawperson
Just an idea
Stage 1: Proposal
Describe shape of solution
Identify potential blockers
Stage 2: Draft
Describe precise syntactic and semantic details
Stage 3: Candidate
Further feedback from implementations and users
Stage 4: Finished
Tested and ready for addition to the standard
阶段 0:Strawperson 稻草人
代表目前仅仅是一个想法。
阶段 1: Proposal 提案
当想法变成提案,就须要进入阶段 1,面向委员会解说和介绍,你须要概述解决方案,并且提出一些潜在的艰难。委员会可能会承受你的提案,但并不代表就要在浏览器中失效。它仅仅是委员会感觉这是一个值得探讨的议题且违心持续探讨。
阶段 2: Draft 草案
进入这一阶段的讨论会更加庄重,须要探讨具体的语法和语义的细节。你须要提供具体的解决方案,如何在语言中实现它,就像一个具体的 API 的实现。
阶段 3: Candidate 候选
这个阶段设计的工作曾经完结,你须要承受来自具体实现者和用户们的反馈。这个阶段也会有不同的 JavaScript 引擎来实现你的新个性。
阶段 4: finished 完结
一旦这个个性被增加进至多两个 JavaScript 实现并且通过具体的测试,代表着能够被大家应用了,提案的规范和标准也会进入到次要的标准规范中,咱们会制订测试去保障将来的实现都会蕴含这项个性,也会增加参考文档。
Building Consensus (达成共识)
Authors develop the proposal with stakeholder input
Champions may act as a bridge between authors and TC39
Any aspects may be discussed,feedback may be given openly
Concerns raised early and asynchronously
Consensus is given as an indicator of the current stage
A delegate may post a constraint as necessary for advancement
Many constraints with rationales,committee may make a trade-off
Stage 3 consensus implies completeness and any design concerns should be raised before Stage 3
作者会从利益相关者 (一些沉闷用户或者提案的推动者) 那里失去一些输出,并造成提案。
支持者们会在作者和 TC39 之间表演中间人的角色,支持者会带着作者实现的提案到 TC39 委员会。
在委员会中,提案的方方面面将会被探讨到,反馈也将公开表白。
会议代表将会表白他们的意见,而后作者和支持者们会针对这些声音作出回应并进一步推动提案。只会探讨以后阶段的提案并达成以后阶段的共识。
当探讨趋势统一时,某个会议代表能够对这个提案进入下一阶段提出限度,能够基于本人对 JavaScript 的视角,提出提案的束缚范畴。
不同的代表都会有本人的见解,每个人的思考准则也不同,大家会进行一些衡量和退让。
阶段 3 会进行比拟非凡的一致性探讨,因为到了候选阶段,意味着所有的 API 设计工作都曾经实现,在此阶段过后将不会轻易的进行更改。
Official communication channels (官网交换渠道)
GitHub
IRC
Discourse
Incubator Calls
TC39
大部分的探讨都在 GitHub,有很多 Issues 会探讨 API 的细节。除此之外还有 IRC(Internet Relay Chat),一个聊天社交媒体。
论文和刊物个别是比拟早阶段的提案所提出的中央,这里有很多人的头脑风暴。
Incubator Calls(孵化阶段的招集),这里通常会招集大家探讨不同利益相关者的提案,
有作者和委员会里对这个提案感兴趣的人。
还有 TC39 官网,中文版的貌似是正在开发。
(群友发了一个中文趣味组)
JavaScript 中文趣味组
TC39 Outreach Groups (TC39 向外拓展工作小组)
TC39 Outreach to important focus groups
Tools and Transpilers
Frameworks
Educators
Monthly calls
Discuss ongoing TC39 proposals
这个小组会和工业界的一些焦点小组进行交换,比方 Babel、TypeScript 等。还有一些大家青睐的很多前端的框架以及一些从事教育工作的人。他们会通过月度的通话来进行工作,探讨一些 TC39 的提案。
How do I get involved?(我如何参加?)
Issue trackers of any relevant proposals
Contribute to documentation on MDN
Discourse to discuss new proposals
File issues,create pull requests and write tests
Your employer can become a member
Join as an invited expert if you care about a specific topic
你能够通过 GitHub 的 Issues 板块去参加任何提案,提出本人的见解和反馈,帮忙给出一些测试。
也能够在 MDN 奉献文档,一些新的提案的文档可能是缺失的,也可能品质不高,这些都是你能够帮忙做到的。
也能够去一些探讨集中的论坛探讨新的提案。
如果你十分感兴趣,我举荐你的公司去成为国际化组织的会员,这样能够提 Issues、创立 pull requests,对阶段 3 的提案写测试,这些测试后果十分有用。
如果你决定参加测试,test262 这里有很多 Issues,能够帮忙你很好的发展工作。
这是一个 test262 测试的例子,就是 JavaScript 比拟常见的测试例子。
如果您对某一畛域有特地的建树,您能够和 TC39 主席团分割,以受邀专家的身份退出。
好了,笔记就整顿到这里了,心愿大家对 TC39 以及 TC39 的 Stage 阶段过程有所理解。
❤️爱心三连击
1. 看到这里了就点个赞反对下吧,你的 赞是我创作的能源。
2. 关注公众号前端食堂,你的前端食堂,记得按时吃饭!
3. 本文已收录在前端食堂 github.com/Geekhyt,求个小星星,感激 Star。