Apollo查询不返回使用readFragment可用的缓存数据。
创始人
2024-09-09 07:00:49
0

要解决“Apollo查询不返回使用readFragment可用的缓存数据”的问题,可以尝试以下解决方法:

  1. 确保在进行查询之前已经执行了对应的写操作,以更新缓存数据。
import { useMutation } from '@apollo/client';

const UPDATE_DATA_MUTATION = gql`
  mutation UpdateData($input: DataInput!) {
    updateData(input: $input) {
      id
      ...
    }
  }
`;

const MyComponent = () => {
  const [updateData] = useMutation(UPDATE_DATA_MUTATION);

  const handleUpdate = async () => {
    await updateData({
      variables: {
        input: {
          id: 'someId',
          ...
        }
      }
    });
  };

  // 在执行查询之前手动更新缓存数据
  useEffect(() => {
    handleUpdate();
  }, []);

  // 执行查询,并使用readFragment获取缓存数据
  const { data } = useQuery(GET_DATA_QUERY);
  const cachedData = useApolloClient().readFragment({
    id: 'someId',
    fragment: gql`
      fragment CachedData on Data {
        id
        ...
      }
    `
  });

  return (
    
{/* 使用缓存数据 */} {cachedData &&

{cachedData.id}

} {/* 显示查询数据 */} {data &&

{data.id}

}
); }
  1. 确保查询的fetchPolicy设置为'cache-first',以便首先从缓存中获取数据。
import { useQuery } from '@apollo/client';

const GET_DATA_QUERY = gql`
  query GetData($id: ID!) {
    getData(id: $id) {
      id
      ...
    }
  }
`;

const MyComponent = () => {
  const { data } = useQuery(GET_DATA_QUERY, {
    variables: {
      id: 'someId',
    },
    fetchPolicy: 'cache-first', // 设置fetchPolicy为'cache-first'
  });

  const cachedData = useApolloClient().readFragment({
    id: 'someId',
    fragment: gql`
      fragment CachedData on Data {
        id
        ...
      }
    `
  });

  return (
    
{/* 使用缓存数据 */} {cachedData &&

{cachedData.id}

} {/* 显示查询数据 */} {data &&

{data.id}

}
); }
  1. 确保查询的结果在缓存中存在,可以使用cache.evict方法清除缓存并重新进行查询。
import { useQuery } from '@apollo/client';

const GET_DATA_QUERY = gql`
  query GetData($id: ID!) {
    getData(id: $id) {
      id
      ...
    }
  }
`;

const MyComponent = () => {
  const { data } = useQuery(GET_DATA_QUERY, {
    variables: {
      id: 'someId',
    },
  });

  const cachedData = useApolloClient().readFragment({
    id: 'someId',
    fragment: gql`
      fragment CachedData on Data {
        id
        ...
      }
    `
  });

  const refetchData = async () => {
    // 清除缓存
    await useApolloClient().cache.evict({ id: 'someId' });
    // 重新查询
    await useApolloClient().query({
      query: GET_DATA_QUERY,
      variables: {
        id: 'someId',
      },
    });
  };

  return (
    
{/* 使用缓存数据 */} {cachedData &&

{cachedData.id}

} {/* 显示查询数据 */} {data &&

{data.id}

}
); }

这些解决方法可以帮助确保使用readFragment时能够返回可用的缓存数据。根据具体的场景和使用情况,选择适合的解决方法。

相关内容

热门资讯

透视教学!wpk透视工作室,w... 透视教学!wpk透视工作室,wpk模拟器多开,我来教教你(有挂规律)1、首先打开wpk模拟器多开最新...
透视辅助!wpk有那种辅助吗,... 透视辅助!wpk有那种辅助吗,wpk有作弊吗,安装教程(有挂方法)运wpk有那种辅助吗辅助工具,进入...
透视有挂!wpk免费辅助,wp... 透视有挂!wpk免费辅助,wpk真吗,切实教程(有挂解密)1、完成wpk免费辅助的残局,帮助玩家取得...
透视工具!wpk模拟器是什么,... 透视工具!wpk模拟器是什么,wpk透视是真的吗,力荐教程(有挂解密)小薇(透视辅助)致您一封信;亲...
透视计算!wpk俱乐部辅助器,... 透视计算!wpk俱乐部辅助器,wpk私人局有透视吗,辅助教程(有挂详情);一、wpk私人局有透视吗A...
透视最新!wpk安卓下载辅助,... 透视最新!wpk安卓下载辅助,wpk真吗,分享教程(有挂解说)1、下载好wpk安卓下载辅助辅助软件之...
透视规律!wpk刷入池率脚本,... 透视规律!wpk刷入池率脚本,wpk俱乐部怎么作弊,AI教程(有挂细节)1、wpk俱乐部怎么作弊系统...
透视软件!wpk辅助购买,wp... 透视软件!wpk辅助购买,wpk私人局有透视吗,存在挂教程(有挂插件);进入游戏-大厅左侧-新手福利...
透视中牌率!wpk有辅助器吗,... 透视中牌率!wpk有辅助器吗,wpk辅助,解说技巧(有挂方法)1、用户打开应用后不用登录就可以直接使...
透视辅助!wpk有那种辅助吗,... 透视辅助!wpk有那种辅助吗,如何下载wpk透视版,2025新版教程(有挂详情)1、进入游戏-大厅左...