ES6,ES5,TypeScript区别

作者: wave浪儿 | 来源:发表于2018-09-29 17:30 被阅读28次

TypeScript 是 JavaScript 的超集。ES2015 是 ES5 的改进版本。

一、概念区分

  • ECMAScript: 一个由 ECMA International 进行标准化,TC39 委员会进行监督的语言。通常用于指代标准本身。
  • JavaScript: ECMAScript 标准的各种实现的最常用称呼。这个术语并不局限于某个特定版本的 ECMAScript 规范,并且可能被用于任何不同程度的任意版本的 ECMAScript 的实现。
  • ECMAScript 5 (ES5):ECMAScript 的第五版修订,于 2009 年完成标准化。这个规范在所有现代浏览器中都相当完全的实现了。
  • ECMAScript 6 (ES6) / ECMAScript 2015 (ES2015):ECMAScript 的第六版修订,于 2015 年完成标准化。这个标准被部分实现于大部分现代浏览器。

下面是一些ES6中的新的特点:

  • ES6中的let命令,声明变量,用法和var差不多,但是let是为JavaScript新增了块级作用域,ES5中是没有块级作用域的,并且var有变量提升的概念,但是在let中,使用的变量一定要进行声明。
  • ES6中变量的解构赋值,比如:var [a,b,c] = [0,1,2];
  • ES6中不再像ES5一样使用原型链实现继承,而是引入Class这个概念,听起来和Java中的面向对象编程的语法有些像,但是二者是不一样的。
  • ES6中的函数定义也不再使用关键字function,而是利用了=>来进行定义;
  • ES6中可以设置默认函数参数,如function A(x,y=9){};
    更多es6语法知识

二、TypeScript

typescript相对于ES5有五大改善:
  • 类型
  • 注解
  • 模块导入
  • 语言工具包(比如,结构)
typescript相对于ES6,TypeScript最大的改善是增加了类型系统。

更多TypeScript语法知识

三、总结

TypeScript 的价值并不在于编写更少的代码,其价值在于编写更加安全的代码。从长远看来,它能帮助我们利用其工具识别问题并自动填充参数、属性、函数以及更多东西(通常被成为自动补全和智能感知),从而更有效率的编写出代码。

相关文章

  • TypeScript入门

    慕课网@JoJozhai 老师 TypeScript入门课程分享 TypeScript入门 ES5,ES6,JS,...

  • ts知识

    1、ES5、ES6是脚本语言规范,javascript是基于ES5规范的,typescript是基于ES6规范的。...

  • TypeScript入门

    TypeScript起步入门 typeScript的存在,无疑就是为了更加规范化,是继ES5,ES6之后更加高级的...

  • ES6,ES5,TypeScript区别

    TypeScript 是 JavaScript 的超集。ES2015 是 ES5 的改进版本。 一、概念区分 EC...

  • ES6,ES5,TypeScript区别

    下面是一些ES6中的新的特点: ES6中的let命令,声明变量,用法和var差不多,但是let是为JavaScri...

  • TypeScript笔记

    ts 是什么? Typescript 是JavaScript的超集,遵循ES5/ES6规范,扩展了Javascri...

  • ReactNative中ES5和ES6的区别

    ReactNative中ES5和ES6的区别 在ReactNative项目中有些用的es5,有些用的es6,有的是...

  • ES6常见面试题总结

    1、es5和es6的区别,说一下你所知道的es6 ECMAScript5,即ES5,是ECMAScript的第五次...

  • ES5, ES2015 和 TypeScript 的区别

    ES5,ES2015(原名 ES6 )和 TypeScript 之间有什么不同?我们应该学习和使用哪一个? 首先,...

  • ES6 类和ES5 构造函数

    ES5的构造函数和ES6的Class区别 ES5的构造函数的原型上的属性和方法可以遍历/ES6 不能够遍历 ES6...

网友评论

    本文标题:ES6,ES5,TypeScript区别

    本文链接:https://www.haomeiwen.com/subject/valboftx.html