HTML5技术

es6笔记7^_^class - webNick(2)

字号+ 作者:H5之家 来源:H5之家 2017-01-22 17:00 我要评论( )

class MyArray extends Array { // Overwrite species to the parent Array constructor static get [Symbol.species]() { return Array; }} var a = new MyArray(1,2,3 ); var mapped = a.map(x = x * x);console.

class MyArray extends Array { // Overwrite species to the parent Array constructor static get [Symbol.species]() { return Array; } } var a = new MyArray(1,2,3); var mapped = a.map(x => x * x); console.log(mapped instanceof MyArray); // false console.log(mapped instanceof Array); // true

9.super 关键字可以用来调用其父类的构造器或者类方法

class Cat { constructor(name) { this.name = name; } speak() { console.log(this.name + ' makes a noise.'); } } class Lion extends Cat { speak() { super.speak(); console.log(this.name + ' roars.'); } } new Lion('nick').speak(); //再看个重要的例子 class Animal4 { constructor(){ this.type = 'animal'; } says(say){ console.log(this.type + ' says ' + say); } } let animal4 = new Animal4(); animal4.says('hello') //animal says hello class Cat4 extends Animal4 { constructor(){ super(); this.type = 'cat'; } } let cat4 = new Cat4(); cat4.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。

es6暂终

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • es6笔记6^_^generator - webNick

    es6笔记6^_^generator - webNick

    2017-01-21 14:00

  • es6笔记5^_^set、map、iterator - webNick

    es6笔记5^_^set、map、iterator - webNick

    2017-01-20 14:00

  • es6笔记4^_^function - webNick

    es6笔记4^_^function - webNick

    2017-01-19 14:00

  • es6笔记3^_^object - webNick

    es6笔记3^_^object - webNick

    2017-01-18 11:00

网友点评