我想从功能中使用type refinements。 如何在流程中创建type guard函数(TypeScript)?
我 TypeScript示例:
function isString(arg: Showable): arg is string {
return typeof arg === 'string';
}
II 流量
/* @flow */
type Showable = number | string;
// ok
function barOk (arg: Showable) {
return typeof arg === 'string' ? arg.length : (arg + 1);
}
// type guard function
function isString(arg: Showable) {
return typeof arg === 'string';
}
// Error
function barError (arg: Showable) {
return isString(arg) ? arg.length : (arg + 1);
// ^ Cannot get `arg.length` because property `length` is missing in `Number`
}
答案 0 :(得分:1)
将您的isString
函数更改为以下内容:
function isString(arg: Showable): boolean %checks {
return typeof arg === 'string';
}