我正在尝试从React应用程序向我的graphQL服务器进行mutation调用。 react代码如下所示:

client.query({
  query: gql`
    mutation{
        addTeam(input:{name:"Somename", label:"somelabel"})
        {error, status}
    }`
 }).then((resp: any) => {
      console.log("Success", resp);
 }).catch(err => {
      throw err;
 })


我收到以下错误:

reactjs - GraphQL突变:不变违反:必须包含查询定义-LMLPHP

但是,如果我将相同的请求从mutation更改为query,并在我的node-graphQL-server中进行必要的更改,以将其作为query而不是mutation来处理,则相同的代码将起作用。

Apollo客户端Mutation docs says


  在GraphQL中,变异与语法查询相同,唯一的区别是您使用关键字mutation而不是query ...


哦,顺便说一句,相同的mutation查询Playground中的WORKS。
请帮助大家,我的工作有点停止了这个问题。

谢谢!

最佳答案

您应该使用客户端的mutate方法进行突变,而不是query方法。可以在in the docs中找到该方法的选项。阿波罗对于如何处理查询和变异抱有看法,因此每种方法都有适用于每种操作行为的不同选项(例如,mutate包括refetchQueries选项)。

client.mutate({
  mutation: gql`
    mutation {
      addTeam(input:{name:"Somename", label:"somelabel"}) {
        error
        status
      }
    }`,
})

关于reactjs - GraphQL突变:不变违反:必须包含查询定义,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/55201963/

10-11 07:00