如何解决对象的类型保护不为空
如何在 TypeScript 中为 对象 设置类型保护?
export function isObject(input: any) :input is Record<string,any> {
return (input !== null) && (typeof input === 'object');
}
但是当我这样使用它时,编译器不会将我检查的变量视为所需的类型:
const constants = {};
const haveConstantsObj = isObject(constants);
// for constants: Object is possibly 'null'.ts(2531)
if (haveConstantsObj && !constants.householdType) {
console.log('hey');
}
我做错了什么?
解决方法
TypeScript 有时有点挑剔。
不是将 isObject
的结果保存到变量中,而是将其包含在同一个 if
检查中并且它可以工作。
export function isObject(input: any) :input is Record<string,any> {
return (input !== null) && (typeof input === 'object');
}
const constants = {};
if (isObject(constants) && !constants.householdType) {
console.log('hey');
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。