javascript - 如何处理 Relay Modern 上的突变错误?

标签 javascript reactjs graphql relayjs relay

我正在为我的客户使用 ReactJS 和 Relay。考虑以下突变:

import {
    commitMutation,
    graphql
} from 'react-relay';

import environment from '../../../../environment';


const mutation = graphql`
    mutation CompanyMutation($company: CompanyInput!) {
        createCompany(data: $company) {
            id
        }
    }
`

export const createCompany = (company, callback) => {

console.log(company);

    const variables = {
        company: company
    }

    commitMutation(
        environment,
        {
            mutation,
            variables,
            onCompleted: () => {
                callback()
            },
            onError: (error) => {
                throw new Error(error)
            },
        },
    );
}

如何处理从我的 GraphQLServer 发送的错误响应:

{
  "errors": [
    {
      "message": "E11000 duplicate key error collection: mom.companies index: name_1 dup key: { : \"TEST

\" }",
      "locations": [
        {
          "line": 4,
          "column": 3
        }
      ],
      "stack": "WriteError({\"code\":11000,\"index\":0,\"errmsg\":\"E11000 duplicate key error collection: mom.companies index: name_1 dup key: { : \\\"RENATO\\\" }\",\"op\":{\"createdAt\":1509103201877,\"deleted\":false,\"name\":\"TEST\",\"ein\":\"1234\",\"test\":false,\"multiSite\":true,\"siteLimit\":10,\"enabled\":false,\"_id\":\"59f316618ba865186815d3de\",\"__v\":0}})\n    at Function.MongoError.create (D:\\9. DEV\\WORKSPACE\\momejected\\node_modules\\mongodb-core\\lib\\error.js:31:11)\n    at toError (D:\\9. DEV\\WORKSPACE\\momejected\\node_modules\\mongodb\\lib\\utils.js:139:22)\n    at D:\\9. DEV\\WORKSPACE\\momejected\\node_modules\\mongodb\\lib\\collection.js:669:23\n    at handleCallback (D:\\9. DEV\\WORKSPACE\\momejected\\node_modules\\mongodb\\lib\\utils.js:120:56)\n    at D:\\9. DEV\\WORKSPACE\\momejected\\node_modules\\mongodb\\lib\\bulk\\unordered.js:465:9\n    at handleCallback (D:\\9. DEV\\WORKSPACE\\momejected\\node_modules\\mongodb\\lib\\utils.js:120:56)\n    at resultHandler (D:\\9. DEV\\WORKSPACE\\momejected\\node_modules\\mongodb\\lib\\bulk\\unordered.js:413:5)\n    at D:\\9. DEV\\WORKSPACE\\momejected\\node_modules\\mongodb-core\\lib\\connection\\pool.js:469:18\n    at _combinedTickCallback (internal/process/next_tick.js:67:7)\n    at process._tickDomainCallback (internal/process/next_tick.js:122:9)",
      "path": [
        "createCompany"
      ]
    }
  ],
  "data": {
    "createCompany": null
  }
}

在那种情况下,onError 不会被调用。

我如何在突变中捕获并处理这个返回的错误?

最佳答案

本文档中的onCompleted 将返回2 个参数,分别是responseerror Relay Modern Mutations

但是在我看来,回调函数不好处理所以我就这样改成了Promise

export const createCompany = (company) =>
  new Promise((resolve, reject) => {
    const variables = {
      company
    };

    commitMutation(
      environment,
      {
        mutation,
        variables,
        onCompleted: (resp, err) => {
          if (err) return reject(err);
          return resolve(resp);
        },
        onError: (err) => {
          return reject(err);
        }
      }
    );
  });

如何在组件中调用

createCompany(company)
  .then((resp) => {
    // handle your response here..
  })
  .catch((err) => {
    // handle your error here..
  })

关于javascript - 如何处理 Relay Modern 上的突变错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46973883/

相关文章:

javascript - 从多个数组属性创建对象

javascript - 如何在 MobileSafari 中接收复制的图像?

javascript - chrome 控制台中的 L 表示什么?

javascript - 获取更改的变量以显示在 `render` 中

javascript - 从 CountDown 子项中 react 设置状态

reactjs - '类型错误: parse is not a function' when using gql

json - 带有桑格利亚汽酒的 GraphQL 模式

javascript - 如何在 JavaScript 或 jQuery 中 1 秒后删除类?

javascript - 如何在 react 中悬停时在图像上添加过渡时间?

graphql - 紧跟查询类型后的字符串的意义(查询/变异)GraphQL