Apollo Client的fetchMore - 缓存已更新,但由useQuery返回的数据未更新。
创始人
2024-09-09 01:31:45
0

问题描述:

当使用Apollo Client的fetchMore方法从服务器获取更多数据时,缓存是正确更新的,但是从useQuery返回的数据却没有更新。

解决方法:

在使用fetchMore方法时,可以使用updateQuery选项来手动更新缓存,并确保从useQuery返回的数据也能正确更新。

下面是一个示例代码,演示了如何使用fetchMore方法并手动更新缓存,以确保从useQuery返回的数据也能正确更新:

import { useQuery } from '@apollo/client';
import { gql } from 'apollo-boost';

const GET_POSTS = gql`
  query GetPosts($start: Int, $limit: Int) {
    posts(start: $start, limit: $limit) {
      id
      title
      content
    }
  }
`;

const PostList = () => {
  const { loading, error, data, fetchMore } = useQuery(GET_POSTS, {
    variables: { start: 0, limit: 10 },
  });

  const handleLoadMore = () => {
    fetchMore({
      variables: { start: data.posts.length, limit: 10 },
      updateQuery: (prev, { fetchMoreResult }) => {
        if (!fetchMoreResult) return prev;
        return Object.assign({}, prev, {
          posts: [...prev.posts, ...fetchMoreResult.posts],
        });
      },
    });
  };

  if (loading) return 

Loading...

; if (error) return

Error: {error.message}

; return (
{data.posts.map((post) => (

{post.title}

{post.content}

))}
); }; export default PostList;

在上面的代码中,我们在fetchMore方法的updateQuery选项中手动更新了缓存。在updateQuery回调函数中,我们将旧的prev查询结果与新的fetchMoreResult查询结果合并,以更新缓存数据。

这样做可以确保缓存和从useQuery返回的数据都能正确更新,并且可以加载更多数据。

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...