我使用的是打字稿,现在定义的接口看起来像这样:
interface SelectProps<T> {
options: T[];
labelKey: keyof T;
valueKey: keyof T;
}
T可以是任何形式的对象,但它必须包含字符串的标签和键,因此我想将T[labelKey]
和T[valueKey]
强制为字符串。我该怎么办?
答案 0 :(得分:2)
type Option<LabelKey extends string, ValueKey extends string> =
Record<string, any> & Record<LabelKey | ValueKey, string>
interface SelectProps<LabelKey extends string, ValueKey extends string> {
options: Option<LabelKey, ValueKey>[];
labelKey: LabelKey;
valueKey: ValueKey;
}
const props: SelectProps<'foo', 'bar'> = {
options: [{ foo: '', bar: '', extra: 3 }],
labelKey: 'foo',
valueKey: 'bar'
}
答案 1 :(得分:0)
我想说的最简单的方法是定义一个基本接口,然后执行以下操作:
interface BaseSelectProps {
valueKey: string;
labelKey: string;
}
interface SelectProps<T extends BaseSelectProps> {
options: T[];
}