如何解决Vue-apollo 从另一个组件重新获取查询
我想知道是否可以从一个组件重新获取查询,以便在不刷新组件本身的情况下在另一个组件中更新它。突变后,我看到 apollo 缓存已更新,但我没有看到其他组件中的数据已经“活动”了。 我的全球阿波罗提取政策是:
watchQuery: {
fetchPolicy: 'cache-and-network'
}
解决方法
我发现,我需要直接使用 update
writeQuery
我的缓存。因为 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 })
}
})
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。