ApolloGraphQL中的useQuery在第一次调用时更新缓存,但fetchMore会怎样呢?
创始人
2024-09-09 10:00:53
0

在 Apollo GraphQL 中,useQuery 是用于查询数据的 React Hook,它可以自动更新缓存。而对于 fetchMore,它用于在已有数据的基础上获取更多数据,不会触发缓存的自动更新。但是我们可以通过一些方法手动更新缓存。

下面是一个示例代码,演示了如何使用 useQueryfetchMore 来获取数据并更新缓存:

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

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

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

  if (loading) {
    return 

Loading...

; } const { posts } = data; const loadMorePosts = () => { fetchMore({ variables: { offset: posts.length }, updateQuery: (prev, { fetchMoreResult }) => { if (!fetchMoreResult) return prev; return { posts: [...prev.posts, ...fetchMoreResult.posts], }; }, }); }; return (
{posts.map((post) => (
{post.title}
))}
); }; export default PostList;

在上述代码中,我们首先定义了一个 GET_POSTS 查询,用于获取文章列表。然后,我们使用 useQuery Hook 来发起查询请求,并在初始时设置了 limitoffset 变量。

当数据加载完成后,我们可以从 data 对象中获取到 posts 数组。然后,我们通过 fetchMore 方法来获取更多的文章数据。在 fetchMore 方法中,我们指定了新的 offset 变量,用于获取下一批数据。我们还通过 updateQuery 参数来手动更新缓存,将新获取到的数据添加到之前的数据中。

最后,我们展示了文章列表,并提供了一个 "Load More" 按钮,点击该按钮时会触发 loadMorePosts 函数,从而获取更多的文章数据。

通过这种方式,我们可以在使用 fetchMore 方法获取更多数据时手动更新缓存,实现缓存的更新和数据的加载。

相关内容

热门资讯

透视普及"wepok... 您好,wepoker线上大神这款游戏可以开挂的,确实是有挂的,需要了解加去威信【485275054】...
透视app"hhpo... 透视app"hhpoker有作必弊的吗"aapoker免费透视脚本(原来是有辅助安装)-哔哩哔哩1、...
透视推荐"hhpok... 透视推荐"hhpoker智能辅助插件"本来是有辅助攻略(哔哩哔哩)透视推荐"hhpoker智能辅助插...
透视辅助"wepok... 透视辅助"wepoker开脚本视频"we poker辅助器v3.3(果然真的有辅助安装)-哔哩哔哩所...
透视了解"hhpok... 透视了解"hhpoker有没有作必弊挂"切实是有辅助神器(哔哩哔哩)1、hhpoker有没有作必弊挂...
透视ai"德普之星怎... 透视ai"德普之星怎么开辅助"wpk作必弊最怕三个东西(其实存在有辅助修改器)-哔哩哔哩1、在wpk...
透视解迷"aapok... 透视解迷"aapoker怎么设置提高好牌几率"确实是有辅助器(哔哩哔哩)aapoker怎么设置提高好...
现场直击"菠萝辅助器... 现场直击"菠萝辅助器免费版的特点"aapoker透视脚本(竟然是真的辅助修改器)-哔哩哔哩1、下载好...
透视曝光"pokem... 透视曝光"pokemmo手机脚本辅助器"切实真的是有辅助挂(哔哩哔哩)1、超多福利:超高返利,海量正...
目前来看"wepok... 目前来看"wepoker轻量版透视方法"pokermaster辅助器(总是是真的辅助工具)-哔哩哔哩...