[英]Dynamically assigning object properties based on the value of an array of other objects
[英]Restricting types on object properties in TypeScript dynamically based on other properties
type MatchOperator = "==" | ">" | "<";
type Criteria<T, P extends keyof T> = {
field: P,
value: T[P],
operator: MatchOperator,
}
interface User {
name: string;
age: number;
id: number;
}
const adultCriteria: Criteria<User, "age"> = {
field: "age",
operator: ">",
value: 18
}
有沒有更好的方法來限制基於field
使用 Typescript 的value
類型,如下所述?
const adultCriteria: Criteria<User> = {
field: "age",
operator: ">",
value: 18
}
是的,有可能:
type Criteria<T> = {
[P in keyof T]: {
field: P,
value: T[P],
operator: MatchOperator
}
}[keyof T]
這樣,您將獲得 3 種可能類型的聯合類型組合:
type OnePossibleCriteria = Criteria<User>
type OnePossibleCriteria = {
field: "name";
value: string;
operator: MatchOperator;
} | {
field: "age";
value: number;
operator: MatchOperator;
} | {
field: "id";
value: number;
operator: MatchOperator;
}
當您為其分配一個可靠的值時,它會縮小到其中之一。
const adultCriteria: OnePossibleCriteria = {
field: "age",
value: 18,
operator: ">"
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.