美文网首页
ES5 和ES6的区别

ES5 和ES6的区别

作者: Mokingc | 来源:发表于2019-11-12 11:44 被阅读0次

ECMAScript 5 (ES5):ECMAScript 的第五版,于2009年标准化,该标准已在所有现代浏览器中完全支持。
ECMAScript 6 (ES6)/ ECMAScript 2015 (ES2015):ECMAscript 第 6 版,2015 年标准化。这个标准已经在大多数现代浏览器中部分实现。以下是ES5和ES6之间的一些主要区别:

  • 箭头函数和字符串插值
    const greetings = (name) => {
      return `hello ${name}`;
    }
    
    也可以这样写:
    const greetings = name => `hello ${name}`;  
    
  • const:const 表示无法修改变量的原始值。需要注意的是,const表示对值的常量引用,咱们可以改变被引用的对象的属性值,但不能改变引用本身。
const NAMES = [];
NAMES.push("Jim");
console.log(NAMES.length === 1); // true
NAMES = ["Steve", "John"]; // error    
  • 块作用域:ES6 中 let, const 会创建块级作用域,不会像 var 声明变量一样会被提升。

  • 默认参数:默认参数使咱们可以使用默认值初始化函数。当参数省略或 undefined 时使用默认参数值。f

    unction multiply (a, b = 2) {
       return a * b;
    }
    multiply(5); // 10    
    
  • 类定义与继承
    ES6 引入了对类(class关键字)、构造函数(constructor关键字)和 extend 关键字(用于继承)的语言支持。

  • for-of
    运算符for...of 语句创建一个遍历可迭代对象的循环。展开操作符

    const obj1 = { a: 1, b: 2 }
    const obj2 = { a: 2, c: 3, d: 4}
    const obj3 = {...obj1, ...obj2}
    
  • Promises:
    Promises 提供了一种机制来处理异步操作的结果和错误。可以使用回调来完成相同的事情,但是Promises 通过方法链接和简洁的错误处理来提高可读性。

    const isGreater = (a, b) => {
    return new Promise ((resolve, reject) => {
      if(a > b) {
        resolve(true)
      } else {
        reject(false)
      }
      })
    }
    isGreater(1, 2)
    .then(result => {
      console.log('greater')
      })
     .catch(result => {
      console.log('smaller')
     })
    
  • 模块导出

      const myModule = { x: 1, y: () => { console.log('This is ES5') }}
      export default myModule;
    
  • 导入

    import myModule from './myModule';
    

相关文章

  • ReactNative中ES5和ES6的区别

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

  • ES6 类和ES5 构造函数

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

  • ES6常见面试题总结

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

  • 前端面试题之es6篇(附答案)

    es6面试题 es5和es6的区别,说一下你所知道的es6var、let、const之间的区别es6实现代码数组去...

  • React-Native之Props(属性)

    效果如下: 小结如下: 1.定义组件的属性类型和默认属性(ES5 和ES6中的区别) 在ES5里,属性类型和默认属...

  • vue面试题(第十一天)

    1.ES5/ES6 的继承除了写法以外还有什么区别? ES5和ES6继承最大的区别就是在于:1.ES5先创建子类,...

  • var,let,const的区别

    一 、区别如下 var是ES5的语法,let和const都是ES6的语法。 var有变量提升,其他没有。ES6里就...

  • 【一起来烧脑】入门ES6体系

    为什么要学习ES6掌握ES3、ES5、ES6的联系和区别 快速入门ES6 学会快速构建ES6的编译环境 学习ES6...

  • 你不知道的ES5和ES6继承

    ES5继承和ES6继承的区别,在ES6还没有发布的时候 ,js定义类是以函数的形式,例如 function Te...

  • ES6常见面试问题汇总

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

网友评论

      本文标题:ES5 和ES6的区别

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