我正在尝试约束键,因此它只能引用数字或日期的键。
public static indexOfMin<TItem extends object | number | Date>(array: Array<TItem>, key?: keyof TItem): number {
let min: number = Number.MIN_SAFE_INTEGER;
let index: number = -1;
const length = array.length;
for (let i = 0; i < length; i++) {
const value = Number(isNullOrUndefined(key) ? array[i] : array[i][key]);
if (value < min) {
min = value;
index = i;
}
}
return index;
}
interface IPerson {
name: string;
age: number;
dob: Date;
}
indexOfMin(new Array<IPerson>(), 'name'); // error as name is string.
indexOfMin(new Array<IPerson>(), 'age'); // ok are age is number.
indexOfMin(new Array<IPerson>(), 'dob'); // ok are age is Date.
您也可以通过添加条件类型来实现。它看起来有点复杂,但可以完成工作。在 TypeScript 文档章节中有一个关于分发条件类型的类似示例。
下面是如何定义仅选择数字和日期属性名称的此类类型的示例:
type NumberOrDatePropertyNames<T> = { [K in keyof T]: T[K] extends number | Date ? K : never }[keyof T];
K 是 T 类型的键。然后,您将 T[K] 限制为实际属性的类型,键 K 具有条件类型,如果属性是数字或日期,则返回键 K,否则匹配为 never 这意味着它被忽略。
然后,可以将函数参数更改为使用此类型,并且键将仅限于数字和日期属性。
public static indexOfMin<TItem extends object | number | Date>(array: Array<TItem>, key?: NumberOrDatePropertyName<TItem>): number {
let min: number = Number.MIN_SAFE_INTEGER;
let index: number = -1;
const length = array.length;
for (let i = 0; i < length; i++) {
const value = Number(isNullOrUndefined(key) ? array[i] : array[i][key]);
if (value < min) {
min = value;
index = i;
}
}
return index;
}