执行突变时 Apollo 客户端错误

问题描述

这里又是一个我似乎无法弄清楚的问题。

我正在使用 Apollo Client(带有 react)与我的 GraphQL 服务器进行通信。

当我尝试执行突变时出现错误,我不知道问题出在哪里,因为其他突变工作正常。

这是我遇到问题的突变:

const DELETE_USER_MUTATION = gql`
    mutation deleteUser($id: ID!) {
        deleteUser(id: $id) {
            id
        }
    }
`; 

当我在 GraphQL 游乐场中输入它时,突变工作正常......

这就是我所说的突变(由单击按钮触发):

<button
    onClick={() =>
        deleteUser({
            variables: {
                id: user.id,},})
    }>

注意:user.id是通过查询获得的,是有效的。

最后,deleteUser 函数是这样定义的(使用 useMutation 钩子)

const [deleteUser,{ error }] = useMutation(DELETE_USER_MUTATION,{
    refetchQueries: [{ query: GET_USERS_QUERY }],});

顺便说一句,如何调试此类错误?在控制台上,我收到错误 400,我读到这意味着它可能是突变本身的错误。但我没有得到关于错误的更多信息......我试图抓住它但无济于事。

谢谢!

解决方法

我能够解决这个问题,我不敢相信我没有早点意识到这个问题。

检查 user.id 的类型后,我意识到它是一个字符串而不是一个整数。将其转换为 Int 有效。

但是我现在遇到了一些缓存问题...是时候进行更多研究了