From 0702d90fe1289af1ad749ace3b54915f504b26dd Mon Sep 17 00:00:00 2001 From: devRobertKaplan Date: Thu, 13 Dec 2018 00:10:18 +0800 Subject: [PATCH] custom hooks advice --- README.md | 29 +++++++++++++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 9e49c43..c084e39 100644 --- a/README.md +++ b/README.md @@ -435,13 +435,38 @@ export interface Props { Hooks are supported in `@types/react` from v16.7 up. -Many hooks are initialized with null-ish default values, and you may wonder how to provide types. Do this: +**useState** + +Many hooks are initialized with null-ish default values, and you may wonder how to provide types. Use union types: ```tsx const [user, setUser] = useState(null); + +// later... +setUser(newUser) +``` + +**Custom Hooks** + +If you are returning an array in your Custom Hook, you will want to avoid type inference as Typescript will infer a union type (when you actually want different types in each position of the array). Instead, assert or define the function return types: + +```tsx +export function useLoading() { + const [isLoading, setState] = React.useState(false); + const load = (aPromise: Promise) => { + setState(true); + return aPromise.finally(() => { + setState(false); + }); + }; + return [isLoading, load] as [ + boolean, + (aPromise: Promise) => Promise + ]; +} ``` -If you are writing a React Hooks library, don't forget that you can also expose +If you are writing a React Hooks library, don't forget that you can also expose your types. [Something to add? File an issue](https://github.com/sw-yx/react-typescript-cheatsheet/issues/new).