美文网首页
ES6基础内容用法

ES6基础内容用法

作者: LynnLiu_ | 来源:发表于2019-11-21 17:54 被阅读0次

    let 变量

    let为JavaScript新增了块级作用域。用它所声明的变量,只在let命令所在的代码块内有效。

    let name = 'zach'
    while (true) {
        let name = 'obama'
        console.log(name)  //obama
        break
    }
    console.log(name)  //zach
    

    在外层声明的变量,当在作用域内被更改,也会反映给外层

    let name = 'zach'
    while (true) {
        name = 'obama'
        console.log(name)  //obama
        break
    }
    console.log(name)  //obama
    

    另外一个var带来的不合理场景就是用来计数的循环变量泄露为全局变量,看下面的例子:

    var a = [];
    for (var i = 0; i < 10; i++) {
      a[i] = function () {
        console.log(i);
      };
    }
    a[6](); // 10
    

    上面代码中,变量i是var声明的,在全局范围内都有效。所以每一次循环,新的i值都会覆盖旧值,导致最后输出的是最后一轮的i的值。而使用let则不会出现这个问题。

    var a = [];
    for (let i = 0; i < 10; i++) {
      a[i] = function () {
        console.log(i);
      };
    }
    a[6](); // 6
    

    再来看一个更常见的例子,了解下如果不用ES6,而用闭包如何解决这个问题。

    var clickBoxs = document.querySelectorAll('.clickBox')
    for (var i = 0; i < clickBoxs.length; i++){
        clickBoxs[i].onclick = function(){
            console.log(i)
        }
    }
    

    我们本来希望的是点击不同的clickBox,显示不同的i,但事实是无论我们点击哪个clickBox,输出的都是5。下面我们来看下,如何用闭包搞定它。

    function iteratorFactory(i){
        var onclick = function(e){
            console.log(i)
        }
        return onclick;
    }
    var clickBoxs = document.querySelectorAll('.clickBox')
    for (var i = 0; i < clickBoxs.length; i++){
        clickBoxs[i].onclick = iteratorFactory(i)
    }
    

    const 变量,但是不能改变

    当我们尝试去改变用const声明的常量时,浏览器就会报错。
    const有一个很好的应用场景,就是当我们引用第三方库的时声明的变量,用const来声明可以避免未来不小心重命名而导致出现bug

    Class, extends, super

    <font color=#DC143C>这三个特性涉及了ES5中最令人头疼的的几个部分:原型、构造函数,继承</font>
    ES6提供了更接近传统语言的写法,引入了Class(类)这个概念。新的class写法让对象原型的写法更加清晰、更像面向对象编程的语法,也更加通俗易懂。

    class Animal {
        constructor(){
            this.type = 'animal'
        }
        says(say){
            console.log(this.type + ' says ' + say)
        }
    }
    let animal = new Animal()
    animal.says('hello') //animal says hello
    class Cat extends Animal {
        constructor(){
            super()
            this.type = 'cat'
        }
    }
    let cat = new Cat()
    cat.says('hello') //cat says hello
    

    上面代码首先用class定义了一个“类”,可以看到里面有一个constructor方法,这就是构造方法,而this关键字则代表实例对象。简单地说,constructor内定义的方法和属性是实例对象自己的,而constructor外定义的方法和属性则是所有实例对象可以共享的。

    Class之间可以通过extends关键字实现继承,这比ES5的通过修改原型链实现继承,要清晰和方便很多。上面定义了一个Cat类,该类通过extends关键字,继承了Animal类的所有属性和方法。

    super关键字,它指代父类的实例(即父类的this对象)。子类必须在constructor方法中调用super方法,否则新建实例时会报错。这是因为子类没有自己的this对象,而是继承父类的this对象,然后对其进行加工。如果不调用super方法,子类就得不到this对象。

    <h3>arrow function</h3>

    function(i){return i + 1;} // ES5
    (i) => i + 1; //ES6
    
    function(x, y) {
        x++;
        y--;
        return x + y;
    }
    (x, y) => {x++; y--; return x+y}
    

    <h3>template string</h3>
    这个东西也是非常有用,当我们要插入大段的html内容到文档中时,传统的写法非常麻烦,所以之前我们通常会引用一些模板工具库,比如mustache等等。
    我们原本是要用一堆的'+'号来连接文本与变量,而使用ES6的新特性模板字符串后,我们可以直接这么来写:

    $("#result").append(`
      There are <b>${basket.count}</b> items
       in your basket, <em>${basket.onSale}</em>
      are on sale!
    `);
    

    <font color=#DC143C>用反引号(\)来标识起始,用${}`来引用变量,而且所有的空格和缩进都会被保留在输出之中</font>

    destructuring

    ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring)。

    看下面的例子:

    let cat = 'ken'
    let dog = 'lili'
    let zoo = {cat: cat, dog: dog}
    console.log(zoo)  //Object {cat: "ken", dog: "lili"}
    

    用ES6完全可以像下面这么写:

    let cat = 'ken'
    let dog = 'lili'
    let zoo = {cat, dog}
    console.log(zoo)  //Object {cat: "ken", dog: "lili"}
    

    反过来可以这么写:

    let dog = {type: 'animal', many: 2}
    let { type, many} = dog
    console.log(type, many)   //animal 2
    

    default, rest

    default很简单,意思就是默认值。大家可以看下面的例子,调用animal()方法时忘了传参数,传统的做法就是加上这一句type = type || 'cat' 来指定默认值。

    function animal(type){
        type = type || 'cat'
        console.log(type)
    }
    animal()
    

    如果用ES6我们而已直接这么写:

    function animal(type = 'cat'){
        console.log(type)
    }
    animal()
    

    最后一个rest语法也很简单,直接看例子:

    function animals(...types){
        console.log(types)
    }
    animals('cat', 'dog', 'fish') //["cat", "dog", "fish"]
    

    而如果不用ES6的话,我们则得使用ES5的arguments。

    相关文章

      网友评论

          本文标题:ES6基础内容用法

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