ApolloGraphqlrelayStylePagination阻止了查询从变量的更改中重新获取数据。
创始人
2024-09-09 10:00:39
0

可以尝试使用React hooks中的useMemo来缓存GraphQL操作,并根据变量的更改条件重新调用缓存的操作。从而实现在变量更改时也能重新查询数据。

代码示例如下:

import { useMemo } from 'react';
import { useQuery } from '@apollo/client';
import { graphql } from 'relay-runtime';
import { relayStylePagination } from '@apollo/client/utilities';

const QUERY = graphql`
  query MyQuery($first: Int!, $after: String) {
    items: myQuery(first: $first, after: $after) @connection(key: "myQuery_items") {
      edges {
        node {
          id
          name
        }
      }
      pageInfo {
        endCursor
        hasNextPage
      }
    }
  }
`;

function MyComponent(props) {
  const { first, after } = props;
  
  const queryVariables = useMemo(() => ({ first, after }), [first, after]);

  const { loading, error, data, fetchMore } = useQuery(QUERY, {
    variables: queryVariables,
    fetchPolicy: 'cache-and-network',
    notifyOnNetworkStatusChange: true,
  });

  const loadedData = data?.items?.edges?.map(edge => edge.node) ?? [];
  const pageInfo = data?.items?.pageInfo;

  const fetchMoreData = () => {
    if (!pageInfo?.hasNextPage) return;
    const { endCursor } = pageInfo;

    fetchMore({
      variables: { after: endCursor },
      updateQuery: (prevResult, { fetchMoreResult }) => {
        return relayStylePagination([...prevResult?.items?.edges, ...fetchMoreResult?.items?.edges], fetchMoreResult?.items?.pageInfo, prevResult);
      }
    });
  };

  // your component render code here...
}

在这个示例中,我们使用缓存的GraphQL操作,并在useMemo函数中将变量作为依赖条件。使用fetchMore来在查询结果后继续获取数据,并使用relayStylePagination更新查询结果。

通过这种方法,可以在变量更改时重新获取

相关内容

热门资讯

透视指南书!aa poker辅... 透视指南书!aa poker辅助包(透视)epoker底牌透视(辅助)竟然是真的有工具(哔哩哔哩)1...
透视绝活儿!werplan透视... 透视绝活儿!werplan透视挂(透视)impoker辅助(辅助)确实是真的有脚本(哔哩哔哩)1、每...
透视阶段!聚星ai辅助工具下载... 透视阶段!聚星ai辅助工具下载(透视)智星德州辅助译码插件靠谱吗(辅助)真是一直都是有攻略(哔哩哔哩...
透视模板!来玩app破解版(透... 透视模板!来玩app破解版(透视)pokerworld破解版下载(辅助)原来一直总是有app(哔哩哔...
透视窍要!pokermaste... 透视窍要!pokermaster辅助器(透视)哈糖大菠萝能开挂吗(辅助)都是一直总是有app(哔哩哔...
透视指南!pokermaste... 您好,德州私人局怎么透视这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多...
透视资料!pokemmo手机脚... 透视资料!pokemmo手机脚本(透视)pokerworld辅助器(辅助)好像是真的有攻略(哔哩哔哩...
透视窍门!xpoker辅助(透... 透视窍门!xpoker辅助(透视)pokernow辅助工具(辅助)切实一直总是有软件(哔哩哔哩)在进...
透视窍门!cloudpoker... 透视窍门!cloudpoker外开挂(透视)智星德州插件(辅助)都是真的是有工具(哔哩哔哩)1、玩家...
透视攻略!poker worl... 透视攻略!poker world辅助器(透视)来玩app 德州 辅助(辅助)一直一直都是有app(哔...