Graphql字段中的多个参数

时间:2018-10-03 11:45:28

标签: arguments graphql graphiql

我正在使用GraphQL。 我可以在一个字段中传递一个参数。但是我想知道如何将多个参数传递给一个字段。

这是我的代码: GraphlQL对象类型:价格可用性

const priceAvailability = new GraphQLObjectType({
  name: "priceAvailability",
  description: "Check price and availability of article",
  fields: () => ({
    articleID: {
      type: GraphQLString
    },
    priceType:{
      type:GraphQLString
    },
    stockAvailability: {
      type: StockAvailabilityType,
      resolve(parentValue, args) {

        // stuff to get the price and availability
        return (data = getStockAvailability.getStockAvailability(
          parentValue.isbn, parentValue.omgeving
        ));
      }
    }
  })
});

根查询

const RootQuery = new GraphQLObjectType({
  name: "RootQuery",
  fields: () => ({
    price: {
      type: new GraphQLList(priceAvailability),
      args: [{
      articleID: {
          type: new GraphQLList(GraphQLString),
          description:
            'List with articles. Example: ["artid1","artid2"]'
        },
        priceType: {
          type: new GraphQLList(GraphQLString) ,
          description:
            'PriceType. Example: "SalePrice","CurrentPrice"'
        }]
      },
      resolve: function(_, { articleID , priceType}) {
        var data = [];
        // code to return data here
        return data;
      }
    }
  })
});

架构

module.exports = new GraphQLSchema({
  query: RootQuery
});

这是我在GraphiQL中用于测试的查询:

{
  query: price(articleID:"ART03903", priceType:"SalePrice" ){
        stockAvailability {
          QuantityAvailable24hrs
          QuantityAvailable48hrs
        }
    }
}

我可以通过parentValue.articleID获取articleID,但是在获取parentValue.priceType时遇到问题。

另外GraphiQL告诉我priceType不存在:

  

未知参数“ priceType”。在“ RootQuery”类型的“价格”字段上

1 个答案:

答案 0 :(得分:1)

字段的

args使用对象而不是数组。试试:

args: {
  articleID: {
    type: new GraphQLList(GraphQLString),
    description: 'List with articles. Example: ["artid1","artid2"]'
  },
  priceType: {
    type: new GraphQLList(GraphQLString) ,
    description: 'PriceType. Example: "SalePrice","CurrentPrice"'
  },
}