class-《understanding-ECMAScipt6》

2017-06-07  本文已影响9人  aliyu

前言

记得之前有一次面试,面试官问我,有几种面对对象的设计方式。
我一下懵了,虽然高级程序设计的第六章我看了好多遍,但确实太久没有用了,如果没有准备面试是对面试官的不尊重,我确实有点失礼了。
有些人说,es6,没有必要记那么多种复杂的类的实现方式了。
我偏向于这种说法,prototype单词实在太长,而且类的实现方式隐晦难懂。

示例

/*
* class是关键字
* className是函数名称
* constructor函数等同于之前的函数constructor
* name 是往这个class传入的参数
* sayName 是给函数prototype上添加的方法
*/

class className {
  constructor(name){
    this.name = name;
  }
  sayName(){
    console.log(this.name);
  }
}

为什么用class方法

使用方法

类可以作为参数传入函数
类可以立即执行

//类表达式
let PersonClass1 = class {/*内部代码省略*/};
//命名的类表达式
let PersonClass2 = class PersonClass22 {/*内部代码省略*/};

类内部方法的设定

get

class a {
  get methodName(){

  }
}

set

class a {
  set methodName(){
    
  }
}

生成器方法

class a{
  *createIterator(){
    yield 1;
  }
}

static 静态方法

class a {
  static methodName(){
    
  }
}
//static关键字不能用于constructor方法
//无法获取实例属性,简单的说,就是this底下的值

方法名称可以是变量


let method = 'methodName'

let PersonClass = class {
  [method] (){
    //do something
  }
}

类的继承

示例

//使用extends关键字
//可以用super()来调用父类的constructor
//如果在子类无constructor(),则自动调用父类的super()
class Child extends Parent{
//无constructor
}
//下例和上例相同
class Child extends Parend{
  constructor(args){
    super(...args);
  }
}

super()

备注

Symbol.species 属性

继承自内建对象,子类使用任何父类的方法,都会返回子类的实例
下列内建对象中有Symbol.species

new.target

只可在类的constructor内使用。
在继承时,子类调用父类, new.target 不等于父类名称。
可以通过这个性质,阻止其他方法继承这个类。

上一篇下一篇

猜你喜欢

热点阅读