【发布时间】:2017-01-02 07:50:28
【问题描述】:
我正在使用GraphQL,它运行良好,但是,我似乎无法弄清楚如何将参数传递到我的Event GraphQLObjectType 的fields 部分。
我希望能够将currentUserId(通过令牌给我)传递给Event GraphQLObjectType,这样我就可以添加isAttending 属性。
我已经附上了我基本上想要做的 cmets 代码:
const Event = new GraphQLObjectType({
name: 'Event',
description: 'This represents an Event',
fields: (currentUserId) => { // currentUserId is the parameter I would like to pass in
return {
id: {
type: GraphQLInt,
resolve (event) {
return event.id;
}
},
title: {
type: GraphQLString,
resolve (event) {
return event.title;
}
},
attendees: {
type: new GraphQLList(User),
resolve (event) {
return event.getAttendees()
}
},
// this is what I would like to do
isAttending: {
type: GraphQLBool,
resolve (event) {
return event.getAttendees({
where: {
id: currentUserId // that's the parameter I would like pass in
}
}).then(attendee => {
return (attendee.length > 0 ? true : false);
)};
}
}
// end of what I'm trying to do //
};
}
});
const Query = new GraphQLObjectType({
name: 'Query',
description: 'Root query object',
fields: () => {
return {
events: {
type: new GraphQLList(Event),
args: {
id: {
type: GraphQLInt
}
},
resolve (root, args) {
// here is the parameter I would like to pass to the event object
let currentUserId = root.userId;
////////
return Db.models.event.findAll({ where: args });
}
},
...
更新
我不能只做data.currentUserId = root.userId 的原因是因为当我返回collection of event objects 时它不可见,因为传递给我的Event GraphQLOBjectType 的只是{event} 对象。
当我执行data.currentUserId 并且data 内部有一个对象数组时的样子是这样的:
[{objects}, currentUserId: 1]
与我们想要的相反:
[{object, currentUserId: 1}, {anotherObject, currentUserId: 1}]
如果我想访问Event GraphQLObject 中的currentUserId,我唯一能想到的就是遍历每个对象并将currentUserId 添加到它上面,如下所示:
return events.map(event => {
event.currentUserId = currentUserId;
return event;
});`
这是最好的解决方案吗?
【问题讨论】:
标签: node.js express graphql graphql-js