typeScript--[es6class类实现继承]

一.js中实现继承

javascript 复制代码
// js实现继承
// 父类
function Father(name) {
    this.name = name
    this.say = function () {
        console.log(this.name + "在唱歌")
    }
}
var f = new Father("逍遥的码农")

// 子类
function Son(name) {
    Father.call(this, name)
}
Son.prototype = Father.prototype
var s = new Son("张三")
s.say()

二.ts中实现继承

TypeScript 复制代码
// ts class类实现继承
// ts父类
class TsFather {
    name: string
    // 构造函数
    constructor(name: string) {
        this.name = name

    }
    say(): void {
        console.log(this.name + "在唱歌")
    }
}
var tsf = new TsFather("逍遥的码农")

// ts子类
class TsSon extends TsFather {
    constructor(name: string) {
        super(name)
    }
}
var tss = new TsSon("张三")
tss.say()

三.ts里的三种修饰符

(1)public:公有,在类里面、子类、类外面都可以访问(默认的就不做演示)

(2)protected:保护类型,在雷里面、子类里面可以访问,在类外部不能访问

(3)private:私有,在类里面可以访问,子类、类外边不能访问

protected:

TypeScript 复制代码
class A {
    protected name: string
    constructor(name: string) {
        this.name = name
    }
}
var a = new A("张三")
console.log(a.name) //属性"name"受保护,只能在类"A"及其子类中访问。

private:

TypeScript 复制代码
class A {
    private name: string
    constructor(name: string) {
        this.name = name
    }
}
var a = new A("张三")
class B extends A{
    constructor(name:string){
        super(name)
        
    }
    say():void{
        console.log(this.name) //属性"name"为私有属性,只能在类"A"中访问。
    }
}
var b = new B("李四")
b.say()
相关推荐
真夜12 小时前
el-table递归表头的坑
前端·vue.js·typescript
亦黑迷失12 小时前
canvas + ts 实现将图片一分为二的功能,并打包发布至 npm
前端·typescript·canvas
小钰能吃三碗饭16 小时前
第二篇:【前端进阶之道】现代 JavaScript 高级特性实战指南
前端·javascript·typescript
太阳花ˉ17 小时前
(一)栈结构、队列结构
typescript
莫循瑾木19 小时前
如何在大型项目中有效使用TypeScript进行类型定义?
前端·typescript·前端工程化
vvilkim1 天前
深入理解 TypeScript 中的 implements 和 extends:区别与应用场景
前端·javascript·typescript
孟陬2 天前
引入模式匹配到 TypeScript 中:介绍 TS-Pattern
typescript
io无心3 天前
node_modules\deasync: Command failed.
typescript·yarn
记得早睡~3 天前
leetcode51-N皇后
javascript·算法·leetcode·typescript
sen_shan3 天前
Vue3+Vite+TypeScript+Element Plus开发-04.静态菜单设计
前端·javascript·typescript·vue3·element·element plus·vue 动态菜单