So I have object in typescript used in react components that has this type:
export type DataInfoTypes<dataType> = {
data: dataType | null;
loading: boolean;
error: boolean;
};
Let's assume that "dataType" there would be (should not matter, just an object of strings):
{[key in string]: string}
Then when I use this data in React component, I check if object.data is not null:
if (!materials.data || materials.loading) {
return <DataLoading />;
}
Then in my return function, when I reference data it seems okay:
<Flex alignItems="center" direction="column">
<Text>{materials.data["somekey"]}</Text>
<VStack w="100%" ....
However few lines down I have an array map method(in same component, same return):
<VStack w="100%" align="center">
{sources.map((matKey: string, index: number) => {
return <Text key={index}>{materials.data["somekey"]}</Text>
}
</VStack>
And I get this error:
Object is possibly 'null'. TS2531
Any ideas on how to fix this or what is the cause? (Please exclude all the tsignore solutions if possible)
Big thanks to everyone responding.
The declared type of data
is dataType
or null
. What the ts compiler is telling you is that you are trying to access a property ( .someKey
) of a possibly null
value, which will result into a runtime error.
To fix it, use optional chaining :
materials.data?.somekey
which will return the value of data.somekey
when data
is not null
and undefined
when data
is null
.
Most importantly, optional chaining does not throw a runtime error when data
is falsy.
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.