ECMAScript和JavaScript的区别是什么?根据我的推断,ECMAScript是标准,JavaScript是实现。这对吗?
当前回答
ECMAScript = en:
ECMAScript是脚本语言的标准。 像Javascript这样的语言是基于ECMAScript标准的。 ECMA标准基于几种原始技术,最著名的是JavaScript (Netscape)和JScript (Microsoft)。 ECMA的意思是欧洲计算机制造商协会
JavaScript = JS:
JavaScript is the most popular implementation of the ECMAScript Standard. The core features of Javascript are based on the ECMAScript standard, but Javascript also has other additional features that are not in the ECMA specifications/standard. ActionScript and JScript are other languages that implement the ECMAScript. JavaScript was submitted to ECMA for standardization but due to trademark issues with the name Javascript the standard became called ECMAScript. Every browser has a JavaScript interpreter.
ES5 = ECMAScript 5:
ES5是ECMAScript的一个版本(旧版本/当前版本)。 ES5是你现在所知道并在浏览器中使用的JavaScript。 ES5不需要构建步骤(编译器)来将其转换为可以在当前浏览器中运行的内容。 ECMAScript第五版于2009年12月完成, 所有主要浏览器(Chrome、Safari、Firefox和IE)的最新版本 已经实现了版本5。 5.1版于2011年6月完成。
ES6 = ES2015 = ECMAScript 2015:
ES2015是ECMAScript(新/未来版本)的一个版本。 官方名称应该是ES2015,而不是ES6。 ES6将解决许多核心语言缺陷 TypeScript和CoffeeScript。 ES6是JavaScript的下一个迭代,但它不能在今天的浏览器中运行。 有相当多的编译器将导出ES5以便在浏览器中运行。
通天塔:
BabelJS是最流行的将新的JavaScript ES6转换为旧的JavaScript ES5的编译器。 BabelJS使得今天编写下一代JavaScript成为可能(意味着ES2015)。 BabelJS只是将ES2015文件转换为ES5文件。 当前的浏览器版本现在可以理解新的JavaScript代码(ES2015),即使它们还不支持它。
TypeScript和CoffeeScript:
两者都在ES5的基础上提供了语法糖 然后被编译成兼容ES5的JavaScript。 你编写TypeScript或CoffeeScript,然后转译器将其转换为ES5 JavaScript。
其他回答
ECMAScript是JavaScript的标准,看看MDN中的这些语句:
JavaScript
JavaScript (JS)是一种轻量级的解释或jit编译的 具有一流函数的编程语言。虽然它是最 作为Web页面的脚本语言而闻名,许多非浏览器 环境也使用它,如node.js, Apache CouchDB和Adobe 杂技演员。JavaScript是基于原型的、多范式的、动态的 语言,支持面向对象、命令式和声明式 (例如函数式编程)风格。阅读更多关于JavaScript的内容。
ECMAScript
The standard for JavaScript is ECMAScript. As of 2012, all modern browsers fully support ECMAScript 5.1. Older browsers support at least ECMAScript 3. On June 17, 2015, ECMA International published the sixth major version of ECMAScript, which is officially called ECMAScript 2015, and was initially referred to as ECMAScript 6 or ES6. Since then, ECMAScript standards are on yearly release cycles. This documentation refers to the latest draft version, which is currently ECMAScript 2018.
欲了解更多信息,请访问这里
总称:
JavaScript = ECMAScript + DOM +炸弹;
ECMAScript®语言规范定义了创建和编辑对象、数组、数字等的所有逻辑… DOM(文档对象模型)使得与HTML/XML文档(例如Document . getelementbyid ('id');)通信成为可能。 BOM(浏览器对象模型)是浏览器对象的层次结构(例如位置对象,历史对象,表单元素)。
JavaScript命名的历史:
Mocha►LiveScript►JavaScript(语言)►(JS的一部分结果)►ECMA-262►ECMAScript►JavaScript(总称,由ECMAScript + DOM + BOM组成)
我觉得该上一堂历史课了。
JavaScript最初被命名为Mocha,后来改为Livescript,但最终变成了JavaScript。
值得注意的是,JavaScript出现在ECMAscript之前,历史会告诉你为什么。
从头开始,JavaScript的名字来源于Java,最初Brendan Eich (JS的创造者)被要求为Netscape开发一种类似于Java的web语言。
然而,Eich认为Java的所有规则都太复杂了,所以开始创建一种更简单的语言,即使是初学者也可以编写代码。这在一些事情上很明显,比如放松对分号的需求。
在语言完成后,Netscape的营销团队要求Sun允许他们将其命名为JavaScript作为营销噱头,这就是为什么大多数从未使用过JavaScript的人认为它与Java有关。
在JavaScript在浏览器中发布大约一两年之后,微软的IE采用了这种语言,并开始制作自己的实现,比如JScript。与此同时,IE在市场上占据主导地位,不久之后网景不得不关闭它的项目。
在网景公司倒闭之前,他们决定建立一个标准来指导JavaScript的发展,命名为ECMAScript。
ECMAScript有几个版本,在1999年,他们发布了最后一个版本(ECMAScript 3),然后就进入了接下来10年的休眠状态。在这10年里,微软主导了市场,但与此同时,他们没有改进自己的产品,因此诞生了Firefox(由Eich领导)和一大堆其他浏览器,如Chrome, Opera。
ECMAScript在2009年发布了第5版(第4版被放弃了),具有严格模式等特性。从那时起,ECMAScript获得了很大的发展势头,并计划在几个月后发布第6版,其中有迄今为止最大的变化。
您可以在这里使用ECMAScript 6的特性列表http://kangax.github.io/es5-compat-table/es6/以及浏览器支持。你甚至可以像编写CoffeeScript一样开始编写Ecmascript 6,并使用编译器编译到Ecmascript 5。
ECMAScript是否是一种语言,JavaScript是否是一种方言是有争议的,但并不重要。如果你继续这样想,你可能会困惑。没有编译器可以运行ECMAScript,我相信JavaScript被认为是实现ECMAScript标准的语言。
还有其他值得注意的实现ECMAScript的语言,如ActionScript(用于Flash)
从技术上讲,ECMAScript是每个人都在使用和实现的语言——它是许多年前Netscape和Microsoft坐下来试图在JavaScript (Netscape的脚本语言)和JScript (Microsoft的脚本语言)之间标准化脚本时创建的规范。
随后,所有这些引擎表面上都实现了ECMAScript,然而JavaScript(这个名字)现在因为传统的命名原因而存在,并且作为Mozilla用于各种非标准扩展的营销术语(他们希望能够真正“版本”)。
JavaScript是一种ECMAScript语言。
ECMAScript不一定是JavaScript。
推荐文章
- JavaScript: override alert()
- 重置setTimeout
- 如何确保<select>表单字段被禁用时提交?
- jQuery有不聚焦的方法吗?
- 反应钩子-正确的方式清除超时和间隔
- TypeScript枚举对象数组
- 在React.js中正确的img路径
- 在React.js中更新组件onScroll的样式
- onClick ReactJS调用多个函数
- 如何在JavaScript中转义单引号(')?
- Ng-repeat结束事件
- 谷歌MAP API未捕获的类型错误:无法读取属性“offsetWidth”为空
- 模糊vs聚焦-有什么真正的区别吗?
- 如何使用JavaScript创建和样式一个div ?
- 清除JavaScript中的缓存