使用graphql-yoga的子字段上的Graphql错误

red*_* 87 5 javascript node.js graphql prismic.io

我正在尝试通过另一个 graphql API 的代理查询 graphql API 并收到错误消息。我正在为我的服务器使用 graphql Yoga 并从 CMS 连接到另一个 graphql API。这是我的代码:

服务器.js

const { GraphQLServer } = require('graphql-yoga');
const Prismic = require('./prismic.config.js');
const gql = require('graphql-tag');

const typeDefs = `
  type Query {
    page(lang: String, uid: String): Page
  }

  type Page {
    page_title: [TextField]
  }

  type TextField {
    text: String
  }
`

const resolvers = {
  Query: {
    page: (parent, args, context, info) => {
      const query = gql`${context.request.body.query}`;

      const result = context.Prismic.query({
        query,
        variables: { ...args }
      })
      .then(resp => {
        return resp.data.page;
      })
      .catch(err => console.log(err));
      return result;
    }
  }
}

const server = new GraphQLServer({ 
  typeDefs, 
  resolvers,
  context: req => ({ ...req, Prismic })
})

server.start(() => console.log('Server is running on localhost:4000'))
Run Code Online (Sandbox Code Playgroud)

这是我从 Graphql Yoga 附带的 graphql playground 中的查询:

query {
  page(lang: "en-gb", uid: "homepage") {
    page_title {
      text
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

我收到的错误是:

'查询未通过验证。违规:\n\n字段 \'page_title\' 类型 \'Json\' 不得有子选择。(第 3 行,第 5 列):\n page_title {\n ^' } },

奇怪的是,如果我在没有嵌套text字段的情况下对查询进行硬编码,就像服务器上的错误提示那样,我可以获得有效的响应:

// const query = gql`${context.request.body.query}`;

const query = gql`
      query($uid: String!) {
        page(lang: "en-gb", uid: $uid) {
          page_title
        }
      }
    `;
Run Code Online (Sandbox Code Playgroud)

尝试在 graphql 操场中修改我的查询以不包含嵌套text字段,如下所示:

query {
  page(lang: "en-gb", uid: "homepage") {
    page_title
  }
}
Run Code Online (Sandbox Code Playgroud)

给我以下错误,并且根本不允许我提出请求:

“[TextField]”类型的字段“page_title”必须有一个子字段选择。您的意思是“page_title { ... }”吗?

该错误表明我需要添加text预期的嵌套子字段,但是当我使用此查询而不是服务器上的硬编码查询时,它给了我前面提到的错误。

不确定我是否在设置中的某个地方出错了?

谢谢

Yev*_*huk 2

在您的 GraphQL 模式中 page_title: [TextField]不是标量类型之一

因此,在进行查询期间,您需要定义到底需要获取哪些字段?并且查询中的字段应扩展到仅具有标量类型的级别,以便 GraphQL 将知道如何解析您的查询。

因此,这是唯一应该来自第一级的查询(来自 Graphql Yoga 附带的 graphql Playground):

query {
  page(lang: "en-gb", uid: "homepage") {
    page_title {
     text
    }
  }
}
Run Code Online (Sandbox Code Playgroud)

但是服务器的错误是从您在 graphql 解析器中进行 graphql 查询的方法引发的:

const result = context.Prismic.query({
      query,
      variables: { ...args }
   })
Run Code Online (Sandbox Code Playgroud)

所以我 100% 确定page_titlePrismic 中有自定义标量 - JSON。因此,您无法对此请求使用相同的查询。