Skip to content

Commit

Permalink
Merge pull request #1557 from bvaughn/useDebugValue
Browse files Browse the repository at this point in the history
Add docs for useDebugValue
  • Loading branch information
bvaughn authored Jan 15, 2019
2 parents 165ae04 + efcbcc5 commit df240a4
Showing 1 changed file with 29 additions and 0 deletions.
29 changes: 29 additions & 0 deletions content/docs/hooks-reference.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ If you're new to Hooks, you might want to check out [the overview](/docs/hooks-o
- [`useRef`](#useref)
- [`useImperativeMethods`](#useimperativemethods)
- [`useLayoutEffect`](#uselayouteffect)
- [`useDebugValue`](#usedebugvalue)

## Basic Hooks

Expand Down Expand Up @@ -353,3 +354,31 @@ Prefer the standard `useEffect` when possible to avoid blocking visual updates.
> Tip
>
> If you're migrating code from a class component, `useLayoutEffect` fires in the same phase as `componentDidMount` and `componentDidUpdate`, so if you're unsure of which effect Hook to use, it's probably the least risky.
### `useDebugValue`

```js
useDebugValue(value)
```

`useDebugValue` can be used to display a label for custom hooks in React DevTools.

For example, consider the `useFriendStatus` custom hook described in ["Building Your Own Hooks"](/docs/hooks-custom.html):

```js{6-8}
function useFriendStatus(friendID) {
const [isOnline, setIsOnline] = useState(null);
// ...
// Show a label in DevTools next to this hook
// e.g. "FriendStatus: Online"
useDebugValue(isOnline ? 'Online' : 'Offline');
return isOnline;
}
```

> Tip
>
> We don't recommend adding debug values to every custom hook. It's most valuable for custom hooks that are part of shared libraries.

0 comments on commit df240a4

Please sign in to comment.