admin管理员组文章数量:1345332
I am studying GraphQL
and I get a bit confused from different implementations on the specific issue when writing the fields
of a GraphQLObjectType
.
What is the difference between these two implementations?
1.
var schema = new GraphQLSchema({
query: new GraphQLObjectType({
name: 'RootQueryType',
fields: { // as object
echo: {
type: GraphQLString,
args: {
email: { type: EmailType }
},
resolve: (root, {email}) => {
return email;
}
}
}
})
});
var ComplicatedArgs = new GraphQLObjectType({
name: 'ComplicatedArgs',
fields: () => ({ // as function
plexArgField: {
type: GraphQLString,
args: {
plexArg: { type: ComplexInput }
},
}
}),
});
I am studying GraphQL
and I get a bit confused from different implementations on the specific issue when writing the fields
of a GraphQLObjectType
.
What is the difference between these two implementations?
1.
var schema = new GraphQLSchema({
query: new GraphQLObjectType({
name: 'RootQueryType',
fields: { // as object
echo: {
type: GraphQLString,
args: {
email: { type: EmailType }
},
resolve: (root, {email}) => {
return email;
}
}
}
})
});
var ComplicatedArgs = new GraphQLObjectType({
name: 'ComplicatedArgs',
fields: () => ({ // as function
plexArgField: {
type: GraphQLString,
args: {
plexArg: { type: ComplexInput }
},
}
}),
});
Share
Improve this question
edited Nov 22, 2022 at 20:14
Yilmaz
49.9k18 gold badges217 silver badges270 bronze badges
asked Sep 19, 2016 at 18:01
itaieditaied
7,10713 gold badges59 silver badges94 bronze badges
1
-
What difference in particular do you refer to? The first snippet creates a whole schema with a query type and a resolvable
echo
field, the second snippet only creates an object type with aplexArgField
field and no resolver. – Bergi Commented Jan 8, 2022 at 7:40
2 Answers
Reset to default 6When you need to make a circular reference.
Look for my similiar answer here
Dynamically creating graphql schema with circular references
This is a great example of CLOSURE. Imagine you have two types in a file and they are referencing each other.
const BookType= new GraphQLObjectType({
name: 'BookType',
fields: { // as object
author: {
type: AuthorType,
resolve: (parentValue, args) => {
// query the author based on your db implementation.
}
} }
})
BookType has a field author and referencing AuthorType. Now imagine you have AuthorType defined under "BookType" referencing BookType
const AuthorType= new GraphQLObjectType({
name: 'AuthorType',
fields: { // as object
books: {
type: new GraphQLList(BookType), //one author might have multiple books
resolve: (parentValue, args) => {
// query the books based on your db implementation.
}
} }
})
So when Javascript engine needs to use BookType
it will see that fields.author.type
is AuthorType and AuthorType is not defined above. So it will give
reference error:AuthorType is not defined
to circumvent this, we turn fields to a function. this function is a CLOSURE function. this is a great example why closures are so helpful.
When js engine reads the file first, it saves all the variables that are referenced inside of a function into memory heap as a closure storage of that function. All the variables that BookType.fields
need are stored into the closure environment of the BookType.fields(). So now if javascript executes the Booktype.fields(), it checks if "AuthorType" is defined inside the function, it is not defined so it checks its closure storage, AuthorType was already stored there in the beginning, so it uses it.
本文标签: javascriptGraphQL fields as a functionStack Overflow
版权声明:本文标题:javascript - GraphQL fields as a function - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743766147a2535269.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论