Apollo是否会缓存从mutation返回的数据?
创始人
2024-09-09 13:01:26
0

Apollo Client默认不会缓存从mutation返回的数据。但是,你可以通过使用Apollo Client的update函数来手动更新缓存。

以下是一个示例,演示了如何在mutation返回数据后手动更新缓存:

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

const client = new ApolloClient({
  // 配置Apollo Client
  cache: new InMemoryCache(),
  // 其他配置项...
});

const ADD_TODO = gql`
  mutation AddTodo($title: String!) {
    addTodo(title: $title) {
      id
      title
    }
  }
`;

const updateCache = (cache, { data }) => {
  // 从mutation返回的数据中获取新创建的todo
  const newTodo = data.addTodo;

  // 从缓存中读取已存在的todos列表
  const existingTodos = cache.readQuery({
    query: GET_TODOS,
  });

  // 将新创建的todo添加到已存在的todos列表中
  cache.writeQuery({
    query: GET_TODOS,
    data: {
      todos: [...existingTodos.todos, newTodo],
    },
  });
};

const addTodo = (title) => {
  client.mutate({
    mutation: ADD_TODO,
    variables: { title },
    update: updateCache, // 在mutation返回数据后执行update函数
  });
};

在上面的示例中,updateCache函数使用cache.readQuery从缓存中读取已存在的todos列表,并使用cache.writeQuery将新创建的todo添加到列表中。

请注意,上述示例假设已存在一个名为GET_TODOS的查询,用于获取todos列表。你需要将其替换为你实际使用的查询。

相关内容

热门资讯

透视脚本(wpk俱乐部)德州辅... 透视脚本(wpk俱乐部)德州辅助软件(详细辅助黑科技教程)往昔真的有挂(1)透视脚本(wpk俱乐部)...
透视攻略(wepoke)透明挂... 透视攻略(wepoke)透明挂辅助器(wepoke智能ai)确实有挂(详细透视新2025版);人气非...
透视了解(aapoker有挂)... 透视了解(aapoker有挂)微扑克大厅都是机器人(详细辅助解密教程)总是真的是有挂1)aapoke...
透视软件(wePoKe)外挂透... 1、透视软件(wePoKe)外挂透明挂辅助软件(wepoke有没有挂)都是存在有挂(详细透视可靠教程...
透视神器(wpk有透视辅助)w... 透视神器(wpk有透视辅助)wpk德州辅助器(详细辅助2025新版技巧)本来是有挂1、很好的工具软件...
透视透视(wePOKE)外挂透... 1、透视透视(wePOKE)外挂透明挂辅助技巧(wepoke的确有挂)好像存在有挂(详细透视透明挂教...
透视挂透视(wepokeai代... 透视挂透视(wepokeai代打)德州ai人工智能软件下载(详细辅助力荐教程)起初是有挂;人气非常高...
透视真的(WepokE)透明挂... 透视真的(WepokE)透明挂辅助安装(wepoke辅助挂)起初有挂(详细透视高科技教程)1、很好的...
透视好友房(德州之星辅助)we... 透视好友房(德州之星辅助)wepoke有软件吗(详细辅助切实教程)原来真的有挂是一款可以让一直输的玩...
透视辅助(德州ai机器人)gg... 透视辅助(德州ai机器人)gg扑克发牌系统(详细辅助微扑克教程)原来是有挂1、许多玩家不知道德州ai...