ES6中的class(类)

Posted jishuanghu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES6中的class(类)相关的知识,希望对你有一定的参考价值。

前言

先来复习一下原型对象,原型对象就相当于一个公共的区域,所有同一个类的实例都可以访问到这个原型对象。当我们访问对象的一个属性或方法时,它会先在对象自身中寻找,如果有则直接使用,如果没有则会去原型对象中寻找,如果找到则直接使用。

我们可以将对象中共有的内容,统一设置到原型对象中。在javascript中,class(类)是原型的语法糖。作用就是把一些公共的方法和属性定义在class中,让所有实例共享这些方法和属性。

Class的定义

下面举一个例子来说明 “类” 是如何定义的(摘自阮一峰老师的ECMAScript6入门):

class Point {
  constructor(x, y) {
    this.x = x;
    this.y = y;
  }

  toString() {
    return ‘(‘ + this.x + ‘, ‘ + this.y + ‘)‘;
  }
}

上面代码定义了一个“类”,可以看到里面有一个constructor方法,这就是构造方法,而this关键字则代表实例对象。

Point类除了构造方法,还定义了一个toString方法。注意,定义“类”的方法的时候,前面不需要加上function这个关键字,直接把函数定义放进去了就可以了。另外,方法之间不需要逗号分隔,加了会报错。

类的数据类型就是函数,类本身就指向构造函数。下面来说明下为什么说class是原型的语法糖。事实上,类的所有方法都定义在类的prototype属性上面。

class Point {
  constructor() {
    // ...
  }

  toString() {
    // ...
  }

  toValue() {
    // ...
  }
}

// 等同于

Point.prototype = {
  constructor() {},
  toString() {},
  toValue() {},
};

在类的实例上面调用方法,其实就是调用原型上的方法。

class B {}
let b = new B();

b.constructor === B.prototype.constructor // true

constructor方法

constructor方法是类的默认方法,通过new命令生成对象实例时,自动调用该方法。一个类必须有constructor方法,如果没有显式定义,一个空的constructor方法会被默认添加。

class Point {
}

// 等同于
class Point {
  constructor() {}
}

new.target 属性

new是从构造函数生成实例对象的命令。ES6 为new命令引入了一个new.target属性,该属性一般用在构造函数之中,返回new命令作用于的那个构造函数。Class内部调用new.target,返回当前Class

class Rectangle {
  constructor(length, width) {
    console.log(new.target === Rectangle);
    this.length = length;
    this.width = width;
  }
}

var obj = new Rectangle(3, 4); // 输出 true

需要注意的是,子类继承父类时,new.target会返回子类。

class Rectangle {
  constructor(length, width) {
    console.log(new.target === Rectangle);
    // ...
  }
}

class Square extends Rectangle {
  constructor(length, width) {
    super(length, width);
  }
}

var obj = new Square(3); // 输出 false

以上是关于ES6中的class(类)的主要内容,如果未能解决你的问题,请参考以下文章

ES6中的class(类)

ES6中的class的使用

es6 类

ES6中的class

ES6知识点-class类

ES6-类(Class)