Skip to content

Latest commit

 

History

History
36 lines (29 loc) · 803 Bytes

useAsyncFn.md

File metadata and controls

36 lines (29 loc) · 803 Bytes

useAsyncFn

React hook that returns state and a callback for an async function or a function that returns a promise. The state is of the same shape as useAsync.

Usage

import {useAsyncFn} from 'react-use';

const Demo = ({url}) => {
  const [state, fetch] = useAsyncFn(async () => {
    const response = await fetch(url);
    const result = await response.text();
    return result
  }, [url]);

  return (
    <div>
      {state.loading
        ? <div>Loading...</div>
        : state.error
          ? <div>Error: {state.error.message}</div>
          : <div>Value: {state.value}</div>
      }
      <button onClick={() => fetch()}>Start loading</button>
    </div>
  );
};

Reference

useAsyncFn<Result, Args>(fn, deps?: any[], initialState?: AsyncState<Result>);