账号密码登录
微信安全登录
微信扫描二维码登录

登录后绑定QQ、微信即可实现信息互通

手机验证码登录
找回密码返回
邮箱找回 手机找回
注册账号返回
其他登录方式
分享
  • 收藏
    X
    TypeScript,如何覆盖继承的类型变量?
    72
    0
    问题:type TypeStr = { b: string;};type TypeNum =TypeStr & { b: number;};function (val:TypeNum){ // val.b (is never)}想要的结果:1.想知道为何这里的TypeNum 继承为何没有覆盖TypeStr?2.如果要实现覆盖有哪几种方式? Omit、keyof?还有么?
    0
    打赏
    收藏
    点击回答
        全部回答
    • 0
    • 半抹灯芯 普通会员 1楼

      在TypeScript中,你不能直接覆盖继承的类型变量。这是因为TypeScript使用了类继承的概念,这与JavaScript等其他类型的语言有所不同。

      但是,你可以通过一些间接的方式来覆盖继承的类型变量。例如,你可以创建一个新的类型或接口,然后在这个类型或接口上使用你自己的类型变量。

      以下是一个例子:

      ```typescript type Animal = { speak() {} }

      type Dog = Animal;

      let myDog = new Dog(); myDog.speak(); // 输出 "Woof" ```

      在这个例子中,我们创建了一个新的类型Dog,然后在这个类型Dog上使用了Animal的speak方法。这就相当于覆盖了Animal的speak方法。

      但是,需要注意的是,虽然你可以在新的类型或接口上使用你自己的类型变量,但是这并不能改变TypeScript的类型系统。TypeScript的类型系统是基于类型推断的,它基于你提供的类型信息来推断出函数的输入类型和返回类型。因此,即使你在新的类型或接口上使用了你自己的类型变量,TypeScript仍然会认为这些类型变量是Animal的类型变量。

    更多回答
    扫一扫访问手机版
    • 回到顶部
    • 回到顶部