React Hooks Fetch API с зависимостью от данных - PullRequest
1 голос
/ 04 февраля 2020

Я создал пример React Custom Hook с именем 'useFetch', который принимает URL-адрес, инкапсулирующий API выборки.

Затем я могу вызвать настраиваемый хук для получения данных из конечной точки.

Проблема в том, как мне go использовать результат моей первой выборки для передачи во второй вызов ловушки выборки?

Внутри моей ловушки находится ожидающий вызов API выборки, но он не мешает основному компоненту вызывать второй обработчик выборки.

Пример:

function Home() {

  const result = useFetch("https://google.com/");
  const result2 = useFetch("https://yahoo.com/", result);

  return ( <
    >
    // Use results
    <
    />
  );
}

useFetch Hook - реализация отладки

export default function useFetch(url, data) {
      const [result, setResult] = useState(0);

      async function asyncFetch() {
        let res = await fetch(url);
        setResult(res.url);
      };

      useEffect(() => {
        asyncFetch();
      }, [])

      return res;
    }

useFetch был функцией javascript, которая была импортирована и использована, и мы могли бы определить ее как ожидаемую асин c функцию.

Однако Теперь, когда это зацепка, мы не можем ожидать выполнения useFetch на уровне Home ().

1 Ответ

0 голосов
/ 04 февраля 2020

Для этого варианта использования вы можете выполнить второй вызов в useEffect и добавить свой результат в качестве зависимости. то есть, когда вы получите обновленный результат, useEffect будет выполняться.

useEffect(() => {
   useFetch(url2, result)
}, result)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...