定义如下
export interface Options<T> {
serializer?: (value: T) => string;
deserializer?: (value: string) => T;
defaultValue?: IFunction<T> | T;
}
使用
if (typeof options.defaultValue === "function") {
options.defaultValue();
}
出现下面的报错:
为什么在使用typeof的情况下ts对类型判断还是有问题?平常在消费联合类型的时候,都只需要借助typeof就能达到缩小类型范围的目的,但是这里没有效果,我想问下什么时候会出现这种问题?
我知道解决方案:
- 通过强制的类型断言来告诉ts这是一个函数
- 通过is关键字来做类型预测
但是不知道什么时候需要这么去解决,只有报错的时候才会尝试这么去解决,恳求大佬解惑。
T
也可能是个函数,例如Options<(name: string) => void>
那这时候用
typeof
来收缩函数,就有两个不同签名得函数了,编译器自然无法处理改怎么调用可以单独限制下
defaultValue
泛型为函数得情况: