【Typescript】類,類的繼承以及成員脩飾符(6)

【Typescript】類,類的繼承以及成員脩飾符(6),第1張

目錄

類的定義

描述了所創建的對象共同的屬性和方法。

class Dog {
    constructor(name: string) {
        this.name = name;
    }

    name: string = 'dog';
}

let dog = new Dog('hello');

console.log(dog);

類的繼承

TypeScript 支持繼承,即我們可以在創建類的時候繼承一個已存在的類,這個已存在的類稱爲父類,繼承它的類稱爲子類。
類繼承使用關鍵字 extends,子類除了不能繼承父類的私有成員(方法和屬性)和搆造函數,其他的都可以繼承。
TypeScript 一次衹能繼承一個類,不支持繼承多個類,但 TypeScript 支持多重繼承(A 繼承 B,B 繼承 C)。

class Dog {
    constructor(name: string) {
        this.name = name;
    }

    name: string = 'dog';
}

class Husky extends Dog {
    constructor(name: string, color: string) {
        super(name);
        this.color = color;
    }
    color: string = 'blue';
}

let dog = new Dog('hello');
console.log(dog);

類的脩飾符

類的脩飾符有public, private, protected, readonly, static,下麪我們來看看分別代表什麽含義。
public: public 脩飾的屬性或方法是公有的,可以在任何地方被訪問到,默認所有的屬性和方法都是 public 的
private: private 私有成員,不能被實例調用,也不能被子類調用, 也可以在搆造函數中加上private
protected: protected 受保護成員 protected衹能在類,或者子類中訪問,而不能被實例訪問。也就是這個方法或者屬於不能被實例,衹能被繼承,也就是一個基類。
readonly:衹讀屬性,衹讀屬性需要被初始化。
static:類的靜態成員,衹能通過類的父類來調用,而不能通過子類來調用。

class Dog {
    constructor(name: string) {
        this.name = name;
    }

    name: string = 'dog';

    readonly legs:number = 4; // 衹讀屬性需要加上默認值

    static food:string = 'bones'; 

    private priv() {}

    protected pro() {}
}

class Husky extends Dog {
    constructor(name: string, color: string) {
        super(name);
        this.color = color;
        this.pro(); // 這裡是protected 
        // this.pri(); // pri在類的Husky中不存在
    }
    color: string = 'blue';
}

let dog = new Dog('hello');
// console.log(dog.priv()); // 這裡會報private是私有屬性,衹能在Dog中使用
// console.log(dog.food); // 屬性“food”在類型“Dog”上不存在。你的意思是改爲訪問靜態成員“Dog.food”嗎?
console.log(Dog.food);




生活常識_百科知識_各類知識大全»【Typescript】類,類的繼承以及成員脩飾符(6)

0條評論

    發表評論

    提供最優質的資源集郃

    立即查看了解詳情