Typescript中的继承示例

Typescript代码示例

Typescript

typescript 复制代码
class Animal {
    constructor(public name: string) { }
    move(distanceInMeters: number = 0) {
        console.log(`${this.name} moved ${distanceInMeters}m.`);
    }
}

class Snake extends Animal {
    constructor(name: string) { super(name); }
    move(distanceInMeters = 5) {
        console.log("Slithering...");
        super.move(distanceInMeters);
    }
}

class Horse extends Animal {
    constructor(name: string) { super(name); }
    move(distanceInMeters = 45) {
        console.log("Galloping...");
        super.move(distanceInMeters);
    }
}

let sam = new Snake("Sammy the Python");
let tom: Animal = new Horse("Tommy the Palomino");

sam.move();
tom.move(34);

对应的JavaScript编译结果

JavaScript

javascript 复制代码
var __extends = (this && this.__extends) || (function () {
    var extendStatics = function (d, b) {
        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(name) {
        this.name = name;
    }
    Animal.prototype.move = function (distanceInMeters) {
        if (distanceInMeters === void 0) { distanceInMeters = 0; }
        console.log(this.name + " moved " + distanceInMeters + "m.");
    };
    return Animal;
}());
var Snake = /** @class */ (function (_super) {
    __extends(Snake, _super);
    function Snake(name) {
        return _super.call(this, name) || this;
    }
    Snake.prototype.move = function (distanceInMeters) {
        if (distanceInMeters === void 0) { distanceInMeters = 5; }
        console.log("Slithering...");
        _super.prototype.move.call(this, distanceInMeters);
    };
    return Snake;
}(Animal));
var Horse = /** @class */ (function (_super) {
    __extends(Horse, _super);
    function Horse(name) {
        return _super.call(this, name) || this;
    }
    Horse.prototype.move = function (distanceInMeters) {
        if (distanceInMeters === void 0) { distanceInMeters = 45; }
        console.log("Galloping...");
        _super.prototype.move.call(this, distanceInMeters);
    };
    return Horse;
}(Animal));
var sam = new Snake("Sammy the Python");
var tom = new Horse("Tommy the Palomino");
sam.move();
tom.move(34);

__extends方法解析

1. 整体结构

这是一个立即执行的函数表达式(IIFE),返回一个函数并赋值给 __extends 变量。它用于处理类继承关系。

2. extendStatics 函数

这个内部函数负责复制静态属性和方法:

javascript

css 复制代码
var extendStatics = function (d, b) {
    extendStatics = Object.setPrototypeOf ||  // 优先使用现代方法
        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||  // 兼容老式__proto__赋值
        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };  // 最后回退到逐个属性复制
    return extendStatics(d, b);
}
  • 它会根据环境选择最优的静态属性继承方式
  • 优先级:Object.setPrototypeOf > __proto__赋值 > 逐个属性复制

3. 返回的继承函数

javascript

javascript 复制代码
return function (d, b) {
    extendStatics(d, b);  // 继承静态成员
    
    function __() { this.constructor = d; }  // 中间构造函数
    
    d.prototype = b === null 
        ? Object.create(b)  // 处理继承null的情况
        : (__.prototype = b.prototype, new __());  // 常规继承
};
  • d 是子类,b 是父类
  • 创建中间构造函数 __ 来维护原型链
  • 最后一行是关键:
    • __ 的原型指向父类的原型
    • 然后创建 __ 的实例作为子类的原型
    • 这样既继承了父类的方法,又能保证 constructor 正确指向子类

4. 兼容性处理

这段代码考虑了多种环境:

  1. 现代浏览器:使用 Object.setPrototypeOf
  2. 较老浏览器:使用 __proto__
  3. 最差情况:逐个复制属性

这种实现方式确保了在大多数 JavaScript 环境中都能正确实现类继承机制。

相关推荐
kk不中嘞2 小时前
浅谈前端框架
前端·vue.js·react.js·前端框架
服务端技术栈2 小时前
历时 1 个多月,我的第一个微信小程序「图片转 Excel」终于上线了!
前端·后端·微信小程序
一个很老的小萌新2 小时前
json 解析 [{“id“:1,“name“:“apple“},{“id“:2,“name“:“banana“}]
java·前端·json
yanlele3 小时前
前端面试第 78 期 - 2025.09.07 更新 Nginx 专题面试总结(12 道题)
前端·javascript·面试
影子信息3 小时前
el-tree 点击父节点无效,只能选中子节点
前端·javascript·vue.js
拜无忧3 小时前
完美圆角,渐变边框,兼容chrome 60,两层背景的视觉差
前端·css
徐小夕3 小时前
用Vue3写了一款协同文档编辑器,效果简直牛!
前端·javascript·vue.js
wangbing11253 小时前
界面规范8-文字
前端·javascript·html
盛夏绽放3 小时前
抽成独立组件库:微前端架构下公共组件共享的最佳实践
前端·有问必答
江拥羡橙3 小时前
【目录-单选】鸿蒙HarmonyOS开发者基础
前端·ui·华为·typescript·harmonyos