约束键,使其只能引用数字或日期的键



我正在尝试约束键,因此它只能引用数字或日期的键。

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;
}

最新更新