简体   繁体   中英

Typescript and react - Object is possibly 'null'

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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM