关于javascript:笔记整理D2前端技术论坛-揭秘TC39-ES2020-和-ES2021

10次阅读

共计 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。

正文完
 0