Apollo在mutation改变嵌套子字段时是否自动更新缓存?
创始人
2024-09-09 14:00:13
0

Apollo 默认情况下不会自动更新缓存中的嵌套子字段。但可以使用 update 函数来手动更新缓存。示例代码如下:

import { useMutation } from '@apollo/client';
import { MY_MUTATION } from './myQuery';

function MyComponent() {
  const [myMutation] = useMutation(MY_MUTATION, {
    update(cache, { data: { myMutation } }) {
      // 获取缓存中的数据
      const { someField, nestedField } = cache.readQuery({ query: MY_QUERY });
      
      // 更新嵌套字段的值
      const updatedNestedField = myMutation.updatedNestedField;
      const newData = {
        someField,
        nestedField: {
          ...nestedField,
          updatedNestedField,
        },
      };
      
      // 写入缓存
      cache.writeQuery({
        query: MY_QUERY,
        data: newData,
      });
    },
  });

  return (
    
  );
}

在上述代码中,update 函数会在 mutation 完成后被调用。该函数接收两个参数:cachedatacache 参数可用于读取和写入缓存中的数据。data 参数是 mutation 返回的数据。在示例代码中,我们使用 readQuery 函数从缓存中读取数据,并通过手动更新嵌套字段的值来更新缓存。最后,我们使用 writeQuery 函数将更新后的数据写回到缓存中。

相关内容

热门资讯

第1脚本(德州免费)外挂透明挂... 第1脚本(德州免费)外挂透明挂辅助工具(辅助挂)实用技巧(有挂神器)-哔哩哔哩;德州免费黑科技是一款...
第六安装!开心联盟棋牌俱乐部怎... 第六安装!开心联盟棋牌俱乐部怎么才能赢(辅助挂)太坑了其实真的有挂(确实有挂)-哔哩哔哩1、让任何用...
第8个透明!德扑软件开发(软件... 第8个透明!德扑软件开发(软件购买)辅助透视(有挂教程)-哔哩哔哩;(需添加指定薇757446909...
七个测试!wepoke黑科技(... 七个测试!wepoke黑科技(ai代打)辅助挂(真是有挂)-哔哩哔哩;原来确实真的有挂(需添加指定薇...
4专用(德扑开发)外挂透明挂辅... 4专用(德扑开发)外挂透明挂辅助神器(透视)教你攻略(确实有挂)-哔哩哔哩;德扑开发黑科技是一款具有...
第二是真的!闲逸棋牌挂(透视)... 第二是真的!闲逸棋牌挂(透视)太坑了其实真的有挂(讲解有挂)-哔哩哔哩;一、闲逸棋牌挂AI软件牌型概...
6个苹果版本!德扑之星创建房间... 6个苹果版本!德扑之星创建房间设置(输赢概率计算器)辅助透视(有挂方式)-哔哩哔哩;玩家必备必赢加哟...
三个外挂!wepower软件靠... 三个外挂!wepower软件靠谱(调控参数)辅助挂(有挂秘籍)-哔哩哔哩;超受欢迎的稳赢小游戏,经典...
5俱乐部(pokermaste... 5俱乐部(pokermastersteam外挂)外挂透明挂辅助工具(辅助挂)玩家教程(有挂秘笈)-哔...
第2私人房!星悦游戏辅助神器(... 第2私人房!星悦游戏辅助神器(辅助挂)太坑了原来真的有挂(有挂头条)-哔哩哔哩;无聊就玩这款星悦游戏...