【问题标题】:Vue-apollo refetch query from another componentVue-apollo 从另一个组件重新获取查询
【发布时间】:2021-04-19 14:50:08
【问题描述】:

我想知道是否可以从一个组件重新获取查询,以便在另一个组件中更新它而不刷新组件本身。突变后,我看到阿波罗缓存已更新,但我没有看到我的其他组件中已经“活着”的数据。 我的全球 apollo 获取策略是:

watchQuery: {
  fetchPolicy: 'cache-and-network'
}

【问题讨论】:

    标签: vue.js vuejs2 graphql apollo vue-apollo


    【解决方案1】:

    我发现,我需要直接使用writeQueryupdate 我的缓存。因为refetchQuery 给了你一个新对象,但是如果你想让它变得活泼,你需要在你的 apollo 缓存中改变你现有的对象。一个代码示例是:

      .mutate({
        mutation: CREATE_USER,
        variables: { ...user },
        update(store, { data: { createUser } }) {
          const data = store.readQuery({ query: LIST_USERS })
          data.users.items.push(createUser)
          store.writeQuery({ query: LIST_USERS, data })
        }
      })
    

    【讨论】:

      猜你喜欢
      • 2021-01-27
      • 2020-03-30
      • 2019-11-30
      • 2018-10-08
      • 2019-12-13
      • 1970-01-01
      • 2019-07-03
      • 1970-01-01
      • 2018-07-08
      相关资源
      最近更新 更多