TypeScript中的`extends`继承原理分析

TypeScript是如何实现继承的

在ts中写使用extends继承

class Animal {
    static cell: string = '多细胞';// 静态属性
    hand: number = 2;// 变量
    constructor(hand: number){
        this.hand = hand
    }
    eat(): void{// 方法
        console.log('Animal eat')
    }
}

class Monkey extends Animal {
    foot: number = 2;// 变量
    constructor(hand: number, foot: number){
        super(hand);
        this.foot = foot;
    }
    go (): void{// 方法
        console.log('Monkey go')
    }
}
// 测试
const monkey = new Monkey(2, 4)
console.log(monkey)

运行tsc build命令将上述代码翻译为JavaScript

/**
 * 全局方法,使用this.__extends调用
 * d表示子类
 * b表示父类
 */
var __extends = (this && this.__extends) || (function () {
    // static属性继承
    var extendStatics = function (d, b) {
        // 使用setPrototypeOf将子类__proto__执行父类
        extendStatics = Object.setPrototypeOf ||
            ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
            function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
        return extendStatics(d, b);
    };
    return function (d, b) {
        extendStatics(d, b);
        function __() { this.constructor = d; }
        // 子类原型指向父类原型,
        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
    };
})();
// 父类
var Animal = /** @class */ (function () {
    function Animal(hand) {
        this.hand = 2; // 变量
        this.hand = hand;
    }
    Animal.prototype.eat = function () {
        console.log('Animal eat');
    };
    Animal.cell = '多细胞'; // 静态属性
    return Animal;
}());
// 子类
var Monkey = /** @class */ (function (_super) {
    __extends(Monkey, _super);
    function Monkey(hand, foot) {
        var _this = _super.call(this, hand) || this;
        _this.foot = 2; // 变量
        _this.foot = foot;
        return _this;
    }
    Monkey.prototype.go = function () {
        console.log('Monkey go');
    };
    return Monkey;
}(Animal));
// 测试
var monkey = new Monkey(2, 4);
console.log(monkey);

实际上,变异后的代码采用的js组合寄生继承的方式实现继承,可以简化为如下代码

// 继承
function initExtend(sub, sup){
    // 静态属性继承
    var extendStatics = function(sub, sup){
        for(var property in sup) {
            // 将父类静态属性浅拷贝给子类
            if(sup.hasOwnProperty(property)) {
                sub[property] = sup[property];
            }
        }
        // 子类的原型链__propto__指向父类,官方不推荐使用`setPrototypeOf`属性,而推荐使用`Object.create`
        // Object.setPrototypeOf(sub,sup);
        sub.prototype = Object.create(sup)
    }
    extendStatics(sub, sup);
    function subFun(){
        this.constructor = sub;
    }
    subFun.prototype = sup.prototype;// 继承父类的prototype
    sub.prototype = new subFun();// 子类原型指向subFun实例
}
// 父类
function Animal(){
    this.hand = 2;
}
Animal.cell = '多细胞';// 静态属性
Animal.prototype.eat = function(){
    console.log('Animal eat')
}
// 子类
function Monkey() {
    Animal.apply(this,arguments);
    this.foot = 2;
}
// 1.继承父类的属性和方法
initExtend(Monkey,Animal);
// 2.添加子类自己的方法
Monkey.prototype.go = function(){
    console.log('Monkey go')
}


// 进行测试
const m = new Monkey()

所谓的组合寄生继承是原型继承和构造方法继承的结合体,目的是要完全继承父类的静态属性/方法、普通属性/方法

参考文献

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
提供的源码资源涵盖了Java应用等多个领域,每个领域都包含了丰富的实例和项目。这些源码都是基于各自平台的最新技术和标准编写,确保了在对应环境下能够无缝运行。同时,源码配备了详细的注释和文档,帮助用户快速理解代码结构和实现逻辑。 适用人群: 适合毕业设计、课程设计作业。这些源码资源特别适合大学生群体。无论你是计算机相关专业的学生,还是对其他领域编程感兴趣的学生,这些资源都能为你提供宝贵的学习和实践机会。通过学习和运行这些源码,你可以掌握各平台开发的基础知识,提升编程能力和项目实战经验。 使用场景及目标: 在学习阶段,你可以利用这些源码资源进行课程实践、课外项目或毕业设计。通过分析和运行源码,你将深入了解各平台开发的技术细节和最佳实践,逐步培养起自己的项目开发和问题解决能力。此外,在求职或创业过程,具备跨平台开发能力的大学生将更具竞争力。 其他说明: 为了确保源码资源的可运行性和易用性,特别注意了以下几点:首先,每份源码都提供了详细的运行环境和依赖说明,确保用户能够轻松搭建起开发环境;其次,源码的注释和文档都非常完善,方便用户快速上手和理解代码;最后,我会定期更新这些源码资源,以适应各平台技术的最新发展和市场需求。 所有源码均经过严格测试,可以直接运行,可以放心下载使用。有任何使用问题欢迎随时与博主沟通,第一时间进行解答!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

[email protected]

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值