Apollo客户端使用writeQuery不触发UI更新的问题
创始人
2024-09-09 11:30:21
0

问题描述:

在使用Apollo客户端的过程中,有时候使用writeQuery方法更新缓存数据,但并没有触发UI的更新。

代码示例:

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

const GET_USERS = gql`
  query GetUsers {
    users {
      id
      name
    }
  }
`;

const UPDATE_USER = gql`
  mutation UpdateUser($id: ID!, $name: String!) {
    updateUser(id: $id, name: $name) {
      id
      name
    }
  }
`;

const UserList = () => {
  const client = useApolloClient();

  const { loading, error, data } = useQuery(GET_USERS);

  const handleUpdateUser = async (id, name) => {
    await client.mutate({
      mutation: UPDATE_USER,
      variables: { id, name },
    });

    // 更新缓存数据
    client.writeQuery({
      query: GET_USERS,
      data: {
        users: data.users.map(user => {
          if (user.id === id) {
            return { ...user, name };
          }
          return user;
        }),
      },
    });
  };

  if (loading) return 

Loading...

; if (error) return

Error :(

; return (
{data.users.map(user => (

{user.name}

))}
); };

解决方法:

在更新缓存数据后,需要手动触发UI更新。可以通过在writeQuery方法之后调用client.broadcastQueries()方法来实现。

修改UserList组件中的handleUpdateUser方法如下:

const handleUpdateUser = async (id, name) => {
  await client.mutate({
    mutation: UPDATE_USER,
    variables: { id, name },
  });

  // 更新缓存数据
  client.writeQuery({
    query: GET_USERS,
    data: {
      users: data.users.map(user => {
        if (user.id === id) {
          return { ...user, name };
        }
        return user;
      }),
    },
  });

  // 触发UI更新
  client.broadcastQueries();
};

这样就能保证缓存数据更新后,UI能够正确地进行更新了。

相关内容

热门资讯

科普透视!佛手大菠萝辅助!总是... 科普透视!佛手大菠萝辅助!总是是有辅助软件(有挂功能)-哔哩哔哩1、下载好佛手大菠萝辅助脚本下载之后...
揭幕透视!竞技联盟透视!竟然是... 揭幕透视!竞技联盟透视!竟然是有辅助脚本(有挂透明挂)-哔哩哔哩1、实时竞技联盟透视透视辅助更新:用...
分享透视!佛手在线有挂吗!真是... 分享透视!佛手在线有挂吗!真是是真的有辅助app(有挂辅助)-哔哩哔哩;1、每一步都需要思考,不同水...
总结透视!大菠萝免费辅助!一直... 总结透视!大菠萝免费辅助!一直是真的有辅助方法(确实有挂)-哔哩哔哩;1、下载好大菠萝免费辅助脚本下...
开挂透视!拱趴大菠萝有什么挂!... 开挂透视!拱趴大菠萝有什么挂!竟然真的有辅助脚本(有挂方略)-哔哩哔哩1)拱趴大菠萝有什么挂免费钻石...
了解透视!约局吧能不能开挂!真... 了解透视!约局吧能不能开挂!真是真的是有辅助app(有挂分析)-哔哩哔哩1、全新机制【约局吧能不能开...
解迷透视!德州透视是真的吗!一... 解迷透视!德州透视是真的吗!一直是真的有辅助插件(讲解有挂)-哔哩哔哩德州透视是真的吗透视方法中分为...
分享透视!xpoker辅助!本... 分享透视!xpoker辅助!本来是真的有辅助神器(有挂规律)-哔哩哔哩xpoker辅助是不是有人用挂...
推荐透视!xpoker辅助!其... 推荐透视!xpoker辅助!其实有辅助软件(有挂详细)-哔哩哔哩1、操作简单,无需xpoker辅助手...
关于透视!xpoker辅助神器... 关于透视!xpoker辅助神器!总是是真的有辅助攻略(有挂技巧)-哔哩哔哩1)xpoker辅助神器免...