![GraphQL 使用介绍](http://img.jiangsulong.com/220405/143420I16-0.jpg)
文章插图
GraphQL 是 Fackbook 的一个开源项目,它定义了一种查询语言,用于描述客户端与服务端交互时的数据模型和功能,相比 RESTful API 主要有以下特点:
- 根据需要返回数据
- 一个请求获取多个资源
- 提供内省系统
下面我们从使用的角度来介绍一下 。
相关概念在使用 GraphQL 之前,先介绍几个相关概念,便于理解使用 。
- Operations
- Types
【GraphQL 使用介绍】type User { id: ID name: String}type Query { user: User}定义了 User 类型和包含的字段以及字段的类型;定义 Query 返回一个 User 类型的 user,Query 也是一种类型 。
- Scalar types
标量类型有什么用呢?返回数据的字段必须是标量类型 。例如我们想返回一个 user:
query { user // 报错}上面这样是会报错的,因为 user 不是标量类型,需要改成
query { user { id name }}指定返回 user 的 id 和 name,这两个字段都是标量类型,就可以正确返回了 。
开始使用如果看完上面的介绍,心中有很多疑问,没关系,我们现在以 GitHub GraphQL API 为例,来实际使用一下 。打开 https://developer.github.com/v4/explorer/,然后登录,会看到一个这样的界面
![GraphQL 使用介绍](http://img.jiangsulong.com/220405/1434205418-1.jpg)
文章插图
这是 GraphQL 提供的开发工具 GraphiQL,可以检查 GraphQL 的语法,发送 GraphQL 的请求,还提供文档查询功能 。在开始使用之前先介绍一下文档查询功能 。点击右上角的 < Docs 并可以看到
![GraphQL 使用介绍](http://img.jiangsulong.com/220405/1434204338-2.jpg)
文章插图
上面的 ROOT TYPES 表示最顶层支持的类型,只有两个 Query 和 Mutation 。点击 Query,可以看到该类型包含的字段 。仔细看,会发现这些字段的值又都是类型 。
![GraphQL 使用介绍](http://img.jiangsulong.com/220405/1434203K9-3.jpg)
文章插图
往下滚动,找到 user(login: String!): User,点击 User
![GraphQL 使用介绍](http://img.jiangsulong.com/220405/14342063D-4.jpg)
文章插图
终于找到一个标量类型的字段 bio: String,按照之前说法,我们是可以查询这个字段,写出如下的查询语言:
{ user { bio }}准备执行时,会看到 user 下方有条红线,鼠标放上去
文章插图
提示 user 必须指定一个 login 的参数,再回头看文档中该字段的描述 user(login: String!): User,是不是就可以理解了,(login: ) 表示该字段接受一个 login 参数,为 String 类型,! 表示是必须的 。
将查询语言改成:
{ user(login: "booxood") { bio }}再执行,并得到了我们预期指定的结果
{ "data": { "user": { "bio": "HAppy coding & Happy life" } }}现在是不是有点理解这种查询语言了 。下面我们再以【 Gitalk:一个基于 Github Issue 和 Preact 开发的评论插件】中的两个需求为例
- 展示某个 Issue 的评论和评论上的点赞数据
- 添加或取消某个评论上的点赞
mutation { addReaction(input: {subjectId: "MDEyOklzc3VlQ29tbWVudDMxNTQxOTc2NQ==", content: HEART}) { reaction { content } }}取消
mutation { removeReaction(input: {subjectId: "MDEyOklzc3VlQ29tbWVudDMxNTQxOTc2NQ==", content: HEART}) { reaction { content } }}之前的都是查询,这两个是 mutation,分别调用了 addReaction 和 removeReaction 。
推荐阅读
- 如何使用Photoshop更换证件照底色
- CSS Border 使用分享
- 帕沙古树茶的特点简单介绍
- 福鼎白茶三大产区福鼎白茶特点介绍
- 不粘锅第一次用需要怎么开锅 不粘锅首次使用需要开锅吗
- iPhone提示温度高无法正常使用,看完关键的这几点,手机不再发热
- 学会这几点,使用12306APP购票可以省下不少钱
- 天猫购物券使用规则 天猫双十一购物节采用了哪些促销方式
- 丰谷酒王的品牌介绍与价格
- 三星双开门冰箱报价详情介绍