React useQuery вызывает множество повторных рендеров до и после данных

У меня есть это простое приложение, в котором выполняется вызов API. Я использую response-query для извлечения, а также для кеширования данных. Но если вы поместите консольный журнал, даже если функция заключена в memo, useQuery вызовет несколько повторных рендеров без причины. Должно быть 2 рендера, а не 8.

import React, { memo } from "react";
import logo from "./logo.svg";
import "./App.css";
import { useQuery } from "react-query";
import Axios from "axios";

const fetchTodoList = async (key, id) => {
  const { data } = await Axios.get(
    `https://jsonplaceholder.typicode.com/posts/`
  );
  return data;
};

function App() {
  const { isLoading, isError, data, error } = useQuery("todos", fetchTodoList);
  console.log(isLoading, data);
  if (isLoading) {
    return <span>Loading...</span>;
  }

  if (isError) {
    return <span>Error: {error.message}</span>;
  }

  // also status === 'success', but "else" logic works, too
  return (
    <ul>
      {data.map((todo) => (
        <li key={todo.id}>{todo.title}</li>
      ))}
    </ul>
  );
}

export default memo(App);

0 ответов

Другие вопросы по тегам