让 React Query 在出错时返回之前的数据

Pat*_*zak 6 reactjs axios react-query

React Query 有没有办法在发生错误时返回以前的数据?现在,当出现错误时,所有帖子都会消失,并且我有空白页面,因为数据未定义,但我想保留旧数据。我想在发生错误时保留旧数据。我有 keepPreviousData: true 但这并不能解决问题。

import React from 'react';
import AxiosClient from 'api/axiosClient';
import { createFetchResourcesAction } from 'api/actions/resources/resourcesActions';
import { Post, Resources } from 'api/actions/resources/resources.types';
import { Home } from './Home';

export const HomeContainer = () => {
  const { selectedPage, perPage, handlePageChange } = usePagination();

  const fetchResources = ({ pageParam = 1 }) =>
    AxiosClient.request<Resources<Post>>(createFetchResourcesAction(perPage, pageParam));

  const { data, isError, isFetching } = useQuery(
    ['resources', selectedPage, perPage],
    () => fetchResources({ pageParam: selectedPage }),
    { keepPreviousData: true },
  );

  return (
    <Home
      posts={data?.data.results}
      isLoading={isFetching}
      isError={isError}
      selectedPage={selectedPage}
      numberOfPages={Math.ceil(resolverNumberOfPages())}
      onPageChange={(action, value) => handlePageChange(action, +value)}
    />
  );
};
Run Code Online (Sandbox Code Playgroud)

主页.tsx

import React from 'react';
import { useLocale } from 'hooks';
import { AppMessages } from 'i18n/messages';
import { Post } from './post/Post';
import { Box, Typography } from '@material-ui/core';
import { useStyles } from './Home.style';
import { HomeProps } from './Home.types';
import { Loader, ErrorMessage, Button } from 'ui';
import { Pagination } from 'ui';

export const Home = ({
  posts,
  isLoading,
  isError,
  numberOfPages,
  selectedPage,
  onPageChange,
}: HomeProps) => {
  const { formatMessage } = useLocale();
  const styles = useStyles();

  const handlePageChange = (page: number) => {
    onPageChange('page', page);
  };

  const postList = <>{posts && posts.map(post => <Post post={post} key={post.id} />)}</>;

  return (
    <Box className={styles.home}>
      <Box className={styles.main}>
        <Typography variant="h2" className={styles.title}>
          {formatMessage({ id: AppMessages['home.allEntries'] })}
        </Typography>
        <Box className={styles.postsWrapper}>
          {posts && posts.length < 1 && !isError && !isLoading && (
            <Typography variant="h3" className={styles.genericMessage}>
              {formatMessage({ id: AppMessages['home.noEntries'] })}
            </Typography>
          )}
          {postList}
          {isLoading && <Loader position="fixed" width={60} height={60} />}
          {isError && (
            <ErrorMessage position="top" description={formatMessage({ id: AppMessages['home.errorLoadingEntries'] })} />
          )}
          {isDesktop && numberOfPages > 1 ? (
            <Pagination numberOfPages={numberOfPages} selectedPage={selectedPage} onPageClick={handlePageChange} />
          ) : (
           nyll
          )}
        </Box>
      </Box>
    </Box>
  );
};
Run Code Online (Sandbox Code Playgroud)

创建FetchResourcesAction.ts

import { AxiosRequestConfig } from 'axios';

export const createFetchResourcesAction = (perPage: number, page: number): AxiosRequestConfig => {
  return {
    method: 'get',
    url: /resources?per_page=${perPage}&page=${page},
  };
}
Run Code Online (Sandbox Code Playgroud)

TkD*_*odo 0

据我所知,如果查询从成功状态变为错误状态,react-query 不会从缓存中删除任何数据。如果data你的缓存中有,你就会得到它,即使之后查询出错。所以这是一种可能的状态:

{ state: 'error', isError: true, data: { json from previous successful response }}
Run Code Online (Sandbox Code Playgroud)