我正在尝试在以下形状的 TypeScript 项目中创建自定义 Apollo Client 突变挂钩:
const customApolloMutation = () => {
const [
mutationFunction,
{ data, loading, error, ...result } // or just {...result}
] = useMutation(GRAPHQL_QUERY)
return [mutationFunction,
{ data, loading, error, ...result } // or just {...result}
]
}
export default customApolloMutation ;
一切似乎都很好,但是当我将自定义挂钩导入到另一个文件中时,如下所示:
const [mutationFunction, {data, loading, error}] = customApolloMutation();
...所有解构的道具都会产生 TypeScript 错误,例如Property 'loading' does not exist on type '((options?: MutationFunctionOptions<any, OperationVariables> | undefined) => Promise<FetchResult<any, Record<string, any>, Record<string, any>>>) | { ...; }'.ts(2339)
.
知道我做错了什么吗?我需要添加一些特定的类型吗?我没有正确解构/调用钩子吗?