Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/rauldeheer/use-async-effect
:running: Asynchronous side effects, without the nonsense
https://github.com/rauldeheer/use-async-effect
async async-await await hooks react react-native reactjs use-async-effect useeffect
Last synced: 2 months ago
JSON representation
:running: Asynchronous side effects, without the nonsense
- Host: GitHub
- URL: https://github.com/rauldeheer/use-async-effect
- Owner: rauldeheer
- License: mit
- Created: 2018-11-26T13:24:08.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2023-05-02T12:06:09.000Z (over 1 year ago)
- Last Synced: 2024-11-21T14:05:49.041Z (2 months ago)
- Topics: async, async-await, await, hooks, react, react-native, reactjs, use-async-effect, useeffect
- Language: JavaScript
- Homepage:
- Size: 223 KB
- Stars: 317
- Watchers: 3
- Forks: 19
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![Logo](https://raw.githubusercontent.com/rauldeheer/use-async-effect/master/logo.svg?sanitize=true)
[![npm version](https://badge.fury.io/js/use-async-effect.svg)](https://www.npmjs.com/package/use-async-effect)
[![license](https://badgen.net/npm/license/use-async-effect)](./LICENSE)---
:running: Asynchronous side effects, without the nonsense.
```javascript
useAsyncEffect(async () => {
await doSomethingAsync();
});
```## Installation
```
npm install use-async-effect
```
or
```
yarn add use-async-effect
```This package ships with TypeScript and Flow types.
## API
The API is the same as React's `useEffect()`, except for some notable differences:
- The destroy function is passed as an optional second argument:
```javascript
useAsyncEffect(callback, dependencies?);
useAsyncEffect(callback, onDestroy, dependencies?);
```- The async callback will receive a single function to check whether the callback is still mounted:
```javascript
useAsyncEffect(async isMounted => {
const data1 = await fn1();
if (!isMounted()) return;const data2 = await fn2();
if (!isMounted()) return;doSomething(data1, data2);
});
```> Mounted means that it's running in the current component. It becomes unmounted if the component unmounts, or if the component is re-rendered and the callback is dropped and a new one is called.
## Examples
Basic mount/unmount
```javascript
useAsyncEffect(async () => console.log('mount'), () => console.log('unmount'), []);
```Omitting destroy
```javascript
useAsyncEffect(async () => console.log('mount'), []);
```Handle effect result in destroy
```javascript
useAsyncEffect(() => fetch('url'), (result) => console.log(result));
```Making sure it's still mounted before updating component state
```javascript
useAsyncEffect(async isMounted => {
const data = await fetch(`/users/${id}`).then(res => res.json());
if (!isMounted()) return;
setUser(data);
}, [id]);
```## Linting dependencies list using `ESLint`
The `react-hooks/exhaustive-deps` rule allows you to check your custom hooks.
From the [Advanced Configuration](https://github.com/facebook/react/tree/main/packages/eslint-plugin-react-hooks#advanced-configuration) options:
> `exhaustive-deps` can be configured to validate dependencies of custom Hooks with the `additionalHooks` option. This option accepts a regex to match the names of custom Hooks that have dependencies.‼️ Unfortunately, `react-hooks/rules-of-hooks` isn't configurable and the "Effect callbacks are synchronous to prevent race conditions. Put the async function inside" warning will be displayed.
```json
{
"rules": {
// ...
"react-hooks/exhaustive-deps": [
"warn",
{
"additionalHooks": "(useAsyncEffect|useMyOtherCustomHook)"
}
]
}
}
```