Alb*_*joj 4 laravel reactjs graphql
我正在使用 React,并发送以下信息:
const imageServicesClean = JSON.stringify(imageServices);
const query = `
mutation {
companyUpdate(
idCompany:${idCompany},
name:${nameClean},
imageServices:${imageServicesClean})
{
idCompany
name
imageServices {
idImageService
name
url
key
}
}
}`;
Run Code Online (Sandbox Code Playgroud)
并且 imageServicesClean 以这种方式发送,但返回错误:
[{
"idImageService": 1,
"name": "Service1",
"url": "",
"key": "asdasdas"
}, {
"idImageService": 2,
"name": "Service2",
"url": "sdsads",
"key": "sddsfsds_"
}]
Run Code Online (Sandbox Code Playgroud)
因为我的 GraphQL 服务器(Laravel)只允许不带引号的变量,这样:
[{
idImageService: 1,
name: "Service1",
url: "",
key: "sdofunc4938urcnnwikk"
}, {
idImageService: 2,
name: "Service2",
url: "sdsads",
key: "sddsfsdssss8347yuirh"
}]
Run Code Online (Sandbox Code Playgroud)
因此该函数JSON.stringify
不适用于 GraphQL 中的构建格式。如何在 Javascript 中将对象数组转换为 GraphQL 格式?
最后这是我的解决方案:
const imageServicesClean = JSON.stringify(imageServices);
const graphQLImageServices = imageServicesClean.replace(/"([^(")"]+)":/g,"$1:");
Run Code Online (Sandbox Code Playgroud)
但最后我正在使用这个库,它为我做了一切:https : //github.com/atulmy/gql-query-builder
归档时间: |
|
查看次数: |
3526 次 |
最近记录: |