将对象作为参数传递给 GraphQL Mutation (graphql-request)

R. *_*sch 5 javascript graphql graphql-js express-graphql graphql-mutation

我在前端有一个非常基本的 graphql 突变,我将其发送到后端。我在 by 上使用此代码graphql-request作为指南。

对于原语它可以工作:

const mutation = gql`
    mutation EditArticle($id: ID!, $title: String) {
      editArticle(id: $id, title: $title) {
        id
      }
    }
  `
Run Code Online (Sandbox Code Playgroud)

现在我还希望能够更改有关文章的一些元数据,这些元数据存储在meta文章内的对象中:

...,
title: "Hello World",
meta: {
 author: "John",
 age: 32,
 ...
}
Run Code Online (Sandbox Code Playgroud)

所以我的问题是:当使用graphql-request从前端发出请求时,如何将非原始对象类型作为参数传递给突变?

我已经尝试过这样的事情:

const Meta = new GraphQLObjectType({
    name: "Meta",
    fields: () => ({
      id: { type: GraphQLID },
      name: { type: GraphQLString },
      age ....
    }),
  })
   
const mutation = gql`
    mutation EditArticle($id: ID!, $title: String, $meta: Meta) { //??? I don't seem to get what goes here? 
      editArticle(id: $id, title: $title, meta: $meta) {
        id
      }
    }
  `
Run Code Online (Sandbox Code Playgroud)

我也尝试过GraphQLObjectType,但我认为我在这里出错了(因为这是前端)。

PS:我看了这个答案,但我不明白/相信那里的解决方案可能不完整。

Ber*_*rgi 7

您需要在服务器端架构中定义输入对象类型,例如

input MetaInput {
  name: String
  author: String
  release: Date
}
Run Code Online (Sandbox Code Playgroud)

editArticle并在定义中使用它

extend type Mutation {
  editArticle(id: ID!, title: String, meta: MetaInput): Article
}
Run Code Online (Sandbox Code Playgroud)

MetaInput然后您还可以引用mutation EditArticle.