ES6核心内容(上)

2019-07-30  本文已影响0人  梦醒时分心会凉_

ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准。因为当前版本的ES6是在2015年发布的,所以又称ECMAScript 2015。

并不是所有浏览器都兼容ES6的所有特性,但是目前ES6的在项目中的运用已经原来越多了,就算不使用ES6也应该了解一下E6的语法了

let, const, class, extends, super, arrow functions, template string, destructuring, default, rest arguments      这些都是ES6中常用的几个语法,学会他们就基本不用怕了

let,const

用途个var类似,用来申明变量的,但在实际运用中他们还有各自的特殊用途 例如:

这是因为ES5只有全局作用域和函数作用域,没有块级作用域,这样会出现内层变量覆盖外层变量的情况。

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

const也用来声明变量,但是声明的是常量。一旦声明,常量的值就不能改变。

class, extends, super

这三个特性涉及了ES5中最令人头疼的的几个部分:原型、构造函数,继承

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对象。

ES6的继承机制,实质是先创造父类的实例对象this(所以必须先调用super方法),然后再用子类的构造函数修改this。

arrow function

这个恐怕是ES6最最常用的一个新特性了,用它来写function比原来的写法要简洁清晰很多:

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}

template string

这个东西也是非常有用,当我们要插入大段的html内容到文档中时,传统的写法非常麻烦,所以之前我们通常会引用一些模板工具库,比如mustache等等。

$("#result").append(

  "There are <b>" + basket.count + "</b> " +

  "items in your basket, " +

  "<em>" + basket.onSale +

  "</em> are on sale!"

);

我们要用一堆的'+'号来连接文本与变量,而使用ES6的新特性模板字符串``后,我们可以直接这么来写:

  $("#result").append(`

  There are <b>${basket.count}</b> items

  in your basket, <em>${basket.onSale}</em>

  are on sale!

`);

用${}`来引用变量

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"}

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()

总结

以上就是ES6最常用的一些语法,可以说这20%的语法,在ES6的日常使用中占了80%

上一篇 下一篇

猜你喜欢

热点阅读