如何在 Javascript 中将对象数组转换为 GraphQL 格式?

IT技术 laravel reactjs graphql
2021-05-08 17:09:09

我正在使用 React,并发送以下信息:

const imageServicesClean = JSON.stringify(imageServices);
const query = `
    mutation {
        companyUpdate(
                idCompany:${idCompany},
                name:${nameClean},
                imageServices:${imageServicesClean})
            {
            idCompany
            name
            imageServices {
                idImageService
                name
                url
                key
            }
        }
    }`;

而imageServicesClean就是这样发送的,但是返回错误:

[{
    "idImageService": 1,
    "name": "Service1",
    "url": "",
    "key": "asdasdas"
}, {
    "idImageService": 2,
    "name": "Service2",
    "url": "sdsads",
    "key": "sddsfsds_"
}]

因为我的 GraphQL 服务器(Laravel)只允许不带引号的变量,这样:

[{
    idImageService: 1,
    name: "Service1",
    url: "",
    key: "sdofunc4938urcnnwikk"
}, {
    idImageService: 2,
    name: "Service2",
    url: "sdsads",
    key: "sddsfsdssss8347yuirh"
}]

因此该函数JSON.stringify不适用于 GraphQL 中的构建格式。如何在 Javascript 中将对象数组转换为 GraphQL 格式?

1个回答

最后这是我的解决方案:

const imageServicesClean = JSON.stringify(imageServices);
const graphQLImageServices = imageServicesClean.replace(/"([^(")"]+)":/g,"$1:");

但最后我正在使用这个库,它为我做了一切:https : //github.com/atulmy/gql-query-builder