突变后如何更新阿波罗缓存(使用过滤器查询)

How to update apollo cache after mutation (query with filter)

我是 GraphQL 的新手。我在带有 apollo 的 Vue.js 项目中使用 graph.cool。

但是我希望登录的用户只能看到他们的帖子。所以我用过滤器修改了查询。

query userStreams ($ownerId: ID!) {
  allStreams(filter: {
   owner: {
     id: $ownerId
   }
  }) {
    id
    name
    url
    progress
    duration
    watched
    owner {
      id
    }
  }
}

我的想法是,我只需要传入 userid 变量即可。但是,这是行不通的。我总是得到

Error: Can't find field allStreams({"filter":{"owner":{}}}) on object (ROOT_QUERY) undefined.




this.$apollo.mutate({
      mutation: CREATE_STREAM,
      variables: {
        name,
        url,
        ownerId
      },
      update: (store, { data: { createStream } }) => {
        const data = store.readQuery({
          query: USERSTREAMS,
          variables: {
            id: ownerId
          }
        })
        data.allStreams.push(createStream)
        store.writeQuery({
          query: USER_STREAMS,
          variables: {
            id: ownerId
          },
          data
        })
      }
    })

当你使用readQuery或writeQuery时,你应该使用相同的变量名。所以替换

  variables: { id: ownerId }

  variables: { ownerId }

此外,您收到异常的原因是如果数据不在存储中,readQuery 会抛出异常。这发生在您第一次使用 writeQuery(或使用其他查询获取数据)之前。

您可以在调用此变更之前将一些默认值写入存储。

您也可以使用 returns null 的 readFragment 而不是抛出异常。但这需要对您的代码进行更多更改。