suchen

Heim  >  Fragen und Antworten  >  Hauptteil

Konvertieren Sie die Basisklasseninstanz in eine abgeleitete Klasse ohne Typumwandlung im Typoskript

Ich habe eine neue Klasse aus der Basisklasse erweitert und einige Eigenschaften hinzugefügt. Wie erstelle ich eine Instanz einer abgeleiteten Klasse mithilfe einer bestimmten Basisklasse einschließlich angehängter Eigenschaften?

Dieser Code funktioniert, wandelt aber den Klassentyp um und ist nicht typsicher

Wie geht das ohne Typkonvertierung?

// Base class is imported from a package. Not editable
class BaseClass {
  public x: number;
  public power() {
    return this.x * 2;
  }
}

export interface CustomClass extends BaseClass {
  value: number;
}

function createCustomClass(base: BaseClass, myValue: number): CustomClass {

  // it's not type safe to cast this variable
  // How to do it the right way in Typescript?
  const result: CustomClass = base as CustomClass;
  result.value = myValue;
  return result;
}

P粉451614834P粉451614834320 Tage vor456

Antworte allen(2)Ich werde antworten

  • P粉765570115

    P粉7655701152024-02-26 14:10:39

    我认为使用您的方法不可能完全排除类型转换,但是如果您使用 type Guard 检查变量 result 是否有效 CustomClass (在我的实现中是 isCustomClass ),那将是安全的:

    // Base class is imported from a package. Not editable
    class BaseClass {
      public x: number;
      public power() {
        return this.x * 2;
      }
    }
    
    export interface CustomClass extends BaseClass {
      value: number;
    }
    
    function isCustomClass(classToCheck: any): classToCheck is CustomClass {
      return (
        typeof classToCheck?.value === "number" && classToCheck instanceof BaseClass
      );
    }
    
    function createCustomClass(base: BaseClass, myValue: number): CustomClass {
      const result = base;
      (result as CustomClass).value = myValue;
      if (!isCustomClass(result)) {
        throw new Error("Cannot create valid `CustomClass`");
      }
    
      return result;
    }

    Antwort
    0
  • P粉486138196

    P粉4861381962024-02-26 11:51:43

    您可以使用 Object.assign () 方法 向目标对象添加属性。该方法返回目标对象,以及 其在 TypeScript 库中的调用签名输入类型的交集

    这意味着你的 createCustomClass() 可以这样实现:

    function createCustomClass(base: BaseClass, myValue: number): CustomClass {
      return Object.assign(base, { value: myValue });
    }

    返回类型为 BaseClass & {value: number},其结构与 CustomClass 相同,因此函数编译不会出错,且不存在 需要类型断言

    Playground 代码链接

    Antwort
    0
  • StornierenAntwort