我正在尝试构建一个简单的 GraphQL 模式。我有一个在 localhost 上运行的 json-server 端点,它返回一些简单的 json 数据。
我可以在提供 id 时返回用户。在模式中执行此操作的查询如下所示:
staff: {
type: StaffType,
args: { id: { type: GraphQLInt }},
resolve(parentValue, { id }) {
return axios.get(`http://localhost:3000/staff/${id}`)
.then(resp => resp.data);
}
}
GraphQL 查询如下所示:
{
staff(id: 1){
id
Name
}
}
它在 GraphiQL 客户端中返回:
{
"data": {
"staff": {
"id": 1,
"Name": "John Doe"
}
}
}
当我尝试返回所有用户时,我的问题就开始了。我创建了另一个查询来尝试从http://localhost:3000/staff
没有传入参数的情况下获取所有内容。如果我直接在浏览器中访问此 url,它会按预期返回所有用户。但是,如果我通过 GraphiQL 尝试它,它似乎返回一个对象,但所有字段都是空的。在 GraphiQL 或控制台上都没有给出错误。下面的代码示例:
架构中的查询
allStaff: {
type: StaffType,
resolve(parentValue, args) {
return axios.get(`http://localhost:3000/staff/`)
.then(resp => resp.data);
}
}
GraphiQL 查询
{
allStaff {
id
Name
}
}
我得到的结果
{
"data": {
"allStaff": {
"id": null,
"Name": null,
}
}
}
如果我控制台日志 resp.data 有数据被返回,正如我所说,当我完全按照预期通过浏览器直接访问它时,端点会返回数据。
我错过了什么吗?
谢谢