GraphQL 从 axios 返回空数据



我正在用 Node.js 和 Express 编写一个 GraphQL 服务器。我有一个数据的 JSON 文件,所以我使用 Axios 从该 JSON 文件中查询数据并将其传递给 GraphQL 查询,

const RootQuery = new GraphQLObjectType({
name:'RootQueryType',
fields: {
    holiday: {
        type: Holiday,
        args:{
            date:{type:GraphQLString},
        },
        resolve(parentValue, args) {
            return axios.get('http://localhost:3000/holidays?date='+ args.date).then(res => res.data);
        }
    },

console.log(res.data),我正在获取数据,但是,从 GraphiQL 按日期查询时,我得到了

{ "data": { "holiday": { "holiday": null } } }

我在某个时候遇到了完全相同的问题。我意识到 REST API/JSON 文件中的数据需要一些时间才能获取,而 GraphQL 不会等待接收它。所以我决定使用 Async 和 Await,这样 GraphQL 就等待接收数据。在您的情况下,代码如下所示:

const RootQuery = new GraphQLObjectType({
name:'RootQueryType',
fields: {
    holiday: {
        type: Holiday,
        args:{
            date:{type:GraphQLString},
        },
        Async resolve(parentValue, args) {
            const results= await axios.get('http://localhost:3000/holidays?date='+ args.date)
           .then(res => res.data);
           return results;
        }
    },

最新更新