ES6中的类(class)

目录

一、类(class)

1、在ES6中提供class关键字来定义类

2、在ES6中,支持getter和setter方法的定义,使用getter方法时,采用使用get关键字。使用setter方法时,采用使用set关键字

3、在ES6中提供static关键字类声明静态成员

4、类的继承


一、类(class)

class Person{
    static num = 1001
    constructor(name,gender){//构造方法
        this.name = name;
        this.gender = gender;
    }
    get name(){//用来获取name属性。对象名.name  就会调用该方法
        return this.name;
    }

    set name(newName){//用来设置name属性值。对象名.name='值' 就会调用该方法
        this.name = newName;
    }
    fun(){//普通成员方法
        console.log(`姓名:${this.name},性别:${this.gender}`)//this代表的是实例或者是对象
    }
}

// let p1 = new Person('张三','男');//构造方法里的this,代表的是p1中的对象
// p1.fun()
console.log('编号:',Person.num)

//输出:  编号: 1001

1、在ES6中提供class关键字来定义类

class Person{
    constructor(name,gender){//构造方法
        this.name = name;
        this.gender = gender;
    }
    fun(){//普通成员方法
        console.log(`姓名:${this.name},性别:${this.gender}`)//this代表的是实例或者是对象
    }
}

let p1 = new Person('张三','男');//构造方法里的this,代表的是p1中的对象
p1.fun()
//输出:   姓名:张三,性别:男

2、在ES6中,支持getter和setter方法的定义,使用getter方法时,采用使用get关键字。使用setter方法时,采用使用set关键字

class Person{
    constructor(name,gender){//构造方法
        this.name = name;
        this.gender = gender;
    }
    get name(){//用来获取name属性。对象名.name  就会调用该方法
        return this._name;
    }

    set name(newName){//用来设置name属性值。对象名.name='值' 就会调用该方法
        this._name = newName;
    }
    fun(){//普通成员方法
        console.log(`姓名:${this.name},性别:${this.gender}`)//this代表的是实例或者是对象
    }
}

let p1 = new Person('张三','男');//构造方法里的this,代表的是p1中的对象
// p1.fun()
console.log('编号:',p1._name)

//输出:  编号: 张三

3、在ES6中提供static关键字类声明静态成员

是类的所有对象(实例)共享的属性

class Person{
    static num = 1001//静态属性
    constructor(name,gender){//构造方法
        this.name = name;
        this.gender = gender;
    }
    fun(){//普通成员方法
        console.log(`姓名:${this.name},性别:${this.gender}`)//this代表的是实例或者是对象
    }
}

console.log('编号:',Person.num)
//输出:  编号: 1001
class Student{
    static school = '西安邮电大学';
    constructor(name,gender){
        this.name = name;
        this.gender = gender;
    }
    display(){
        console.log(`学校:${Student.school},姓名:${this.name},性别:${this.gender}`)
    }
}
let s1 = new Student('张三','男');
let s2 = new Student('王氏','女');

s1.display();
s2.display();

/*输出:
学校:西安邮电大学,姓名:张三,性别:男
学校:西安邮电大学,姓名:王氏,性别:女
*/

4、类的继承

ES6标准中类的继承:通过extends关键字实现

class Father{
    constructor(name){
        this.name = name;
    }
    display(){
        console.log(`姓名:${this.name}`)
    }
}

class Son extends Father{
    constructor(name,heigth){
        super(name);
        this.heigth = heigth;
    }
    display(){
        super.display();
        console.log(`身高:${this.heigth}`)
    }
}

let s1 = new Son('张三','175com')
s1.display()
/*输出:
姓名:张三
身高:175com
*/

注意:继承中需要吊桶super()方法继承父类的构造方法。super()在使用过程中需要注意以下两点

(1)在访问this之前一定要调用super()

(2)如果不调用super(),可以让子类构造函数返还一个对象

你可能感兴趣的:(javascript,开发语言)