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)
据我所知,如果查询从成功状态变为错误状态,react-query 不会从缓存中删除任何数据。如果data你的缓存中有,你就会得到它,即使之后查询出错。所以这是一种可能的状态:
{ state: 'error', isError: true, data: { json from previous successful response }}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2205 次 |
| 最近记录: |