成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何在 TypeScript 中使用類和繼承

開發 前端
TypeScript是一種編程語言,它是JavaScript的超集。它通過添加靜態類型、類、接口和模塊等功能來擴展JavaScript。

TypeScript是一種編程語言,它是JavaScript的超集。它通過添加靜態類型、類、接口和模塊等功能來擴展JavaScript

class Hero {
  name: string;
  age: number;

  constructor(name: string, age: number) {
    this.name = name;
    this.age = age;
  }

  say(): void {
    console.log(`my name is ${this.name}`);
  }
}

在上面的代碼中,我們定義了一個名為Hero的類,它具有name和age屬性,以及一個say方法。構造函數用于初始化對象的屬性。

通過類的定義,我們可以創建多個具有相同屬性和行為的對象,實現代碼的復用和封裝。

const Jieke = new Hero('jieke', 28)
Jieke.say();  // 輸出:my name is jieke

繼承和子類

在面向對象編程中,繼承是一種重要的概念。通過繼承,我們可以創建一個類的子類(也稱為派生類),并繼承其屬性和方法。子類可以擴展或修改父類的功能,從而實現代碼的重用和擴展

在TypeScript中,我們使用extends關鍵字來指定一個類繼承自另一個類

class Superman extends Hero {
  heroId: string;

  constructor(name: string, age: number, heroId: string) {
    super(name, age);
    this.heroId = heroId;
  }

  skill(): void {
    console.log(`${this.name}_${this.heroId}.`);
  }
}

我們定義了一個名為Superman的子類,它繼承自Hero父類。子類具有自己的屬性heroId,并通過調用super關鍵字來調用父類的構造函數。

創建子類的實例與創建父類的實例類似:

const s1 = new Superman("Batman", 20, "12345");
s1.say();  // 輸出:my name is Batman
s1.skill();  // 輸出:Batman_12345

限制類的屬性和方法的訪問

在TypeScript中,我們可以使用訪問修飾符來限制類的屬性和方法的訪問。以下是幾個常用的訪問修飾符

  • public(默認):可以在類內部和外部訪問。
  • private:只能在類內部訪問。
  • protected:可以在類內部和子類中訪問,但不能在類外部訪問。

通過使用訪問修飾符,我們可以控制類的成員的可見性,增強了封裝性和安全性

class Person {
  public name: string;
  private age: number;
  protected gender: string;

  constructor(name: string, age: number, gender: string) {
    this.name = name;
    this.age = age;
    this.gender = gender;
  }

  say() {
    console.log(`Hi, my name is ${this.name}.`);
  }

  private sayAge() {
    console.log(`I am ${this.age} years old.`);
  }
}

class Student extends Person {
  constructor(name: string, age: number, gender: string) {
    super(name, age, gender);
  }

  sayGender() {
    console.log(`My gender is ${this.gender}.`);
  }
}

const person = new Person("Tom", 18, "male");
console.log(person.name); // "Tom"
console.log(person.age); // Error: Property 'age' is private and only accessible within class 'Person'.
console.log(person.gender); // Error: Property 'gender' is protected and only accessible within class 'Person' and its subclasses.

const student = new Student("Jane", 20, "female");
console.log(student.gender); // "female"

抽象類

在TypeScript中,我們還可以使用抽象類(abstract class)來定義一個不可實例化的基類。抽象類提供了一種模板,用于派生其他類,并定義了一些必須由子類實現的抽象方法。抽象類不能被直接實例化,只能被繼承

以下是一個抽象類的示例:

abstract class Role {
    // 定義抽象屬性
    abstract name:string; 
    abstract age:number;

    // 定義保護屬性,每個繼承子類都能繼承并調用的屬性
    protected lastPoint!: {x:number,y:number};
    protected status!: "run" | "risk" | "die";

    // 定義保護方法,每個繼承子類都能繼承并調用的方法
    protected getLastPoint (lastPoint:{x:number,y:number}) {
        this.lastPoint = lastPoint;
    }

    // 定義抽象方法,在子類中重寫來執行不同的任務
    abstract attack():void;
}

繼承抽象類的子類實例化對象通過調用同一抽象類規定的抽象方法,來實現了不同的操作,體現了類的多態

class antor extends Role {
    // 重寫抽象屬性
    name: string = "han";
    age: string = 20;

    // 重寫抽象方法
    attack(): void {
        console.log("正在被攻擊");
    }
    constructor () {
        super();
    }
}


責任編輯:華軒 來源: 今日頭條
相關推薦

2022-05-17 08:25:10

TypeScript接口前端

2023-01-05 17:13:28

TypeScript泛型組件

2022-05-10 09:12:16

TypeScript裝飾器

2025-01-20 08:40:00

Python對象

2022-11-18 14:58:34

JavaScript語言TypeScript

2015-01-27 09:16:46

DaaSDRaaS災難恢復

2022-06-23 08:00:53

PythonDateTime模塊

2021-06-09 09:36:18

DjangoElasticSearLinux

2021-03-09 07:27:40

Kafka開源分布式

2015-08-27 09:46:09

swiftAFNetworkin

2011-08-10 09:31:41

Hibernateunion

2024-01-18 08:37:33

socketasyncio線程

2019-09-16 19:00:48

Linux變量

2014-07-02 09:47:06

SwiftCocoaPods

2020-11-30 11:55:07

Docker命令Linux

2024-09-06 11:34:15

RustAI語言

2020-04-09 10:18:51

Bash循環Linux

2018-10-19 09:30:57

SSHSFTPLinux

2022-12-22 20:47:01

腳本循環結構

2021-01-22 05:53:08

C# IndexRange
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 96国产精品久久久久aⅴ四区 | 日韩成人在线播放 | 麻豆精品久久久 | 区一区二在线观看 | 国产在线精品一区二区三区 | 一区二区精品视频 | 亚洲激情第一页 | 不卡欧美 | 国产精品久久久亚洲 | 国产精品电影在线观看 | 精品久久久久久亚洲精品 | 精品一区电影 | 日韩一区二区在线看 | 国产精品一区二区久久久久 | 亚洲精品9999久久久久 | 99视频在线 | 精品一级毛片 | 精品久久香蕉国产线看观看亚洲 | 久久亚洲春色中文字幕久久久 | 国产毛片视频 | 久久成人国产精品 | 亚洲免费一区二区 | 午夜噜噜噜 | 一本一道久久a久久精品综合蜜臀 | 国产日韩一区二区 | 国产一区二区影院 | 欧美一级二级在线观看 | 国产区一区二区三区 | 久久这里只有精品首页 | 天天躁日日躁性色aⅴ电影 免费在线观看成年人视频 国产欧美精品 | 日韩欧美在线一区二区 | 久久久久久精 | 天天拍天天操 | 久久一视频 | 一级欧美日韩 | 亚洲黄色网址视频 | 嫩草网 | 久久久久亚洲国产| 青青草视频网站 | 一区二区三区中文字幕 | 成人高潮片免费视频欧美 |