![](/img/trans.png)
[英]Define class as global variable in Typescript to use without import it in js later
[英]Typescript define class type without defining a JS class?
我想為具有某些屬性的類創建一個 class 類型。 例如:
class Cat {
name = 'cat';
}
class Dog {
name = 'dog';
}
type Animal = ???;
function foo(AnimalClass: Animal) {
console.log((new AnimalClass()).name);
}
我希望doSomething
接受任何具有字符串name
屬性的 class 。 我能做到這一點的唯一方法是:
class _Animal {
name: string;
}
type Animal = typeof _Animal;
有沒有辦法在不定義新的 JS class 的情況下做到這一點? 我只想要類型。
您可以在這里使用 generics 。 我創建了一個類型,使該類型只能分配給 object,名稱屬性為字符串,然后我添加了一個擴展 Animal 類型的泛型類型。 這樣您就不必為 Animal 創建一個新的 class。
class Cat { name = "cat"; age = 2; } class Dog { name = 'dog'; } class Car { brand = "Audi"; } type Animal = {name: string}; function doSomething<T extends Animal>(animal: T) { } doSomething(new Dog()); doSomething(new Cat()); doSomething(new Car()); // typescript error car is missing name
如果你想讓 Animal 類型擴展另一個 class 你可以使用intersection
class Cat { name = "cat"; age = 2; } class Information { year = 2020; } class Dog extends Information { name = 'dog'; } type Animal = { name: string } & Information; function doSomething<T extends Animal>(animal: T) { } doSomething(new Dog()); doSomething(new Cat()); // typescript error cat is missing year
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.