admin管理员组文章数量:1136190
I have a graphql schema, a fragment of which looks like this:
type User {
username: String!
password: String!
}
In graphiql, there is a description field, but it always says "self-descriptive". How do I add descriptions to the schema?
I have a graphql schema, a fragment of which looks like this:
type User {
username: String!
password: String!
}
In graphiql, there is a description field, but it always says "self-descriptive". How do I add descriptions to the schema?
Share Improve this question asked Oct 10, 2016 at 16:37 derekdreeryderekdreery 3,9125 gold badges31 silver badges40 bronze badges 1- 6 PS hash your passwords kids! – derekdreery Commented Oct 11, 2016 at 7:55
3 Answers
Reset to default 169If you're using GraphQL.js version 0.7.0 or above, you can simply add a comment directly before the field, type, or argument you want to describe. For example:
# A type that describes the user
type User {
# The user's username, should be typed in the login field.
username: String!
# The user's password.
password: String!
}
Below version 0.7.0 it is not possible to add descriptions inside the schema language.
UPDATE: since version v0.12.3 you should use string literals
"""
A type that describes the user. Its description might not
fit within the bounds of 80 width and so you want MULTILINE
"""
type User {
"The user's username, should be typed in the login field."
username: String!
"The user's password."
password: String!
}
This is a great question! And actually has a great history in graphql
world.
There were multiple issues, discussions, and Pull Requests on the graphql-js
repo that tried to discuss possible syntax for this, as it was something that a lot of members of the community felt were needed. Thanks to Lee Byron and this Pull Request, we can actually add descriptions to a schema language by using traditional comments.
For example,
// Grab some helpers from the `graphql` project
const { buildSchema, graphql } = require('graphql');
// Build up our initial schema
const schema = buildSchema(`
schema {
query: Query
}
# The Root Query type
type Query {
user: User
}
# This is a User in our project
type User {
# This is a user's name
name: String!
# This is a user's password
password: String!
}
`);
And, if we're using graphql
that's newer than 0.7.0
, the comments are actually turned into the description for the fields or types. We can verify this by running an introspection query on our schema:
const query = `
{
__schema {
types {
name
description,
fields {
name
description
}
}
}
}
`;
graphql(schema, query)
.then((result) => console.log(result));
Which would give us a result that looks like:
{
"data": {
"__schema": {
"types": [
{
"name": "User",
"description": "This is a User in our project",
"fields": [
{
"name": "name",
"description": "This is a user's name"
},
{
"name": "password",
"description": "This is a user's password"
}
]
},
]
}
}
}
And shows us that the #
comments were incorporated as the descriptions for the fields/comments that we put them on.
Hope that helps!
In case you're using a Java implementation ....
For graphql-java
version 7.0 (the latest version as of this writing) with a schema first approach, you can use comments above the field, type, or argument.
String literals are not valid syntax as of version 7.0.
本文标签: javascriptHow do I add a description to a field in quotGraphQL schema languagequotStack Overflow
版权声明:本文标题:javascript - How do I add a description to a field in "GraphQL schema language" - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1736957101a1957631.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论