首页 > 解决方案 > 创建突变后添加到 Apollo 客户端缓存中的数组

问题描述

在通过突变创建项目后,尝试将项目自动添加到 Apollo 客户端中的缓存数组中,第 32 行(data: {)出现 TypeScript 错误:

Type '{ [x: string]: TFetchResultData[]; }' is not assignable to type 'TQuery'.
  '{ [x: string]: TFetchResultData[]; }' is assignable to the constraint of type 'TQuery', but 'TQuery' could be instantiated with a different subtype of constraint 'Record<string, TFetchResultData[]>'.ts(2322)
DataProxy.d.ts(17, 9): The expected type comes from property 'data' which is declared here on type 'WriteQueryOptions<TQuery, TVariables>'

这是完整的代码

import { ApolloCache, DataProxy } from '@apollo/client'

export const addToArray = <
  TVariables,
  TData,
  TFetchResultData,
  TQuery extends Record<string, TFetchResultData[]>,
  K
>(
  cache: ApolloCache<K>,
  {
    query,
    variables,
    fieldName,
    newItem,
  }: {
    query: DataProxy.Query<TVariables, TData>['query']
    variables: DataProxy.Query<TVariables, TData>['variables']
    newItem: TFetchResultData
    fieldName: keyof TQuery
  }
): void => {
  // Add to the documentFiles field, if it exists
  const queryResult = cache.readQuery<TQuery, TVariables>({
    query,
    variables,
  })
  if (queryResult) {
    cache.writeQuery<TQuery, TVariables>({
      query,
      variables,
      data: {
        [fieldName]: [...queryResult[fieldName], newItem],
      },
    })
  }
}

标签: typescriptapolloapollo-client

解决方案


Typescript 抱怨TQuery可能有其他字段会被您的代码剥离。

添加...queryResult到您的writeQuery代码中:

cache.writeQuery<TQuery, TVariables>({
  query,
  variables,
  data: {
     ...queryResult,
    [fieldName]: [...queryResult[fieldName], newItem],
  },
})

推荐阅读