对象的类型保护不为空

问题描述

如何在 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');
}

TypeScript Playground

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...