<返回更多

前端的class类使用方法

2023-11-23  微信公众号  读心悦
加入收藏

ES6引入的class类,让JAVAScript具有更加接近面向对象编程的写法。

ES6之前,想要生成一个实例,只能通过new关键字来调用构造函数来完成。

ES6 使用class来定义类,在类的constructor构造函数中定义实例的属性。原型属性直接在class内部定义并且赋值,类的原型函数的声明,是和constructor构造函数属于同一个层级,并且省略了function关键字。比如:

class Person{
  // 原型属性
  publicName = "duxin";
  constructor(name,age){
    //实例属性
    this.name = name;
    this.age = age;
  }
  //原型函数
  getName(){
    return this.name;
  }
}

// 通过class创建实例
const child = new Person("duxinyues",18);
console.log(child.getName()); // duxinyues

在ES5中的写法为:

//构造函数
function Person(name,age){
  //实例属性
  this.name = name;
  this.age = age;
}

Person.prototype.publicName = "duxin";
Person.prototype.getName = function(){
  return this.name
}

class中有构造函数、静态属性和函数:

constructor构造函数

constructor构造函数,是class类中必须有的一个函数,如果没有手动添加,class也会自动加上一个空的构造函数。

构造函数默认返回对象的实例,也就是默认了this的指向。也可以手动修改构造函数的返回值。

静态属性和函数

如果使用static关键字来修饰静态属性的话,那么实例就不能访问该属性,这个属性只能通过类自身来访问。比如:

class Foo {
    static name = "duxin";
    static getName() {
        return this.name
    }
}

console.log(Foo.getName()); //duxin

静态函数中的this指向是类本身

Class继承

ES6新增的extends关键字,可以快速实现类的继承。

在子类的constructor构造函数中,使用super函数来执行父类的构造函数,然后再来执行子类。比如:

class Parson {
    constructor() {
        this.name = "duxin"
    }

}


class Child extends Parson {
    constructor() {
        super();
        this.age = "908"
    }
}

const child = new Child()
console.log(child.name); // duxin

这就是ES6中class的使用。

关键词:class类      点击(7)
声明:本站部分内容来自互联网,如有版权侵犯或其他问题请与我们联系,我们将立即删除或处理。
▍相关推荐
更多class类相关>>>