[英]How to handle mutation GraphQL error instead of Apollo onError()
服务器端,我抛出一个 403 Forbidden,以管理对 API 调用的访问。
为了捕获突变的 GraphQL 错误,我尝试了以下方法:(方法 #1 在捕获useQuery()
错误时有效)
const [m, { error }] = useMutation(MY_MUTATION);
if(error) {
console.error('Error return #1');
}
try {
await m({
variables,
onError: (e: ApolloError) => {
console.error('Error return #2');
}
}).catch(e) {
console.error('Error return #3');
};
} catch (e) {
console.error('Error return #4');
}
相反,从我的 Apollo onError()
返回以下 GraphQL 错误并停止执行。 它不会 go 进入我的任何突变错误处理尝试:
graphQLErrors:, Array [
Object {
"extensions": Object {
"code": "FORBIDDEN",
"response": Object {
"error": "Forbidden",
"message": "Access is denied.",
"statusCode": 403,
},
},
"message": "Access is denied.",
},
]
如果从useQuery()
返回类似的 GraphQL 错误,则显示它使用:
const { data, error, loading } = useQuery( MY_QUERY );
if(error) {
console.error('Error return #1');
}
基于useMutation 文档,我相信mutate
(或m
) function 不接受onError
回调,你必须在useMutation
选项中设置它。
const [m, { error }] = useMutation(MY_MUTATION, {
onError: (e: ApolloError) => {
console.error('Error return #2');
}
});
if (error) {
console.error('Error return #1');
}
try {
await m({
variables
})
} catch (e) {
console.error('Error return #4');
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.