GraphQL是个什么玩意?
什么是GraphQL?
按照国际惯例,引用官网的话
GraphQL 是一个用于 API 的查询语言,是一个使用基于类型系统来执行查询的服务端运行时(类型系统由你的数据定义)。GraphQL
并没有和任何特定数据库或者存储引擎绑定,而是依靠你现有的代码和数据支撑。
这套官方的话非常的官方,那么通俗的理解,什么是GraphQL?它是一种数据交互的形式,通过GraphQL的一套 规范 进行定义。比如,在使用中,客户端想要数据 {电影名、电影图片、电影简介},服务端可以给一个返回{电影名、电影图片、电影简介}的接口,也可以给一个返回{电影名、电影图片、电影简介、电影评分、演员名字}的接口,但是这样无疑就会有了增加网络传输量,并且不便于处理数据和接口的臃肿(一堆类似接口)
什么是REST API?
根据 百度百科 的解释,
REST(英文:Representational State
Transfer,简称REST)描述了一个架构样式的网络系统,无论是对URL的处理还是对Payload的编码,都倾向于用更加简单轻量的方法设计和实现。REST没有一个明确的标准,更像是一种设计的风格或者约束条件。满足这些约束条件和原则的应用程序或设计就是
RESTful
GraphQL对比REST?
以下内容来自 博友 phantom_111
REST API开发中遇到的问题: 扩展性 ,随着API的不断发展,REST API的接口会变得越来臃肿。 无法按需获取
,一个返回id, name, age, city, addr, email的接口,如果仅获取部分信息,如name,
age,却必须返回接口的全部信息,然后从中提取自己需要的。坏处不仅会增加网络传输量,并且不便于client处理数据
一个请求无法获取所需全部资源
,例如client需要显示一篇文章的内容,同时要显示评论,作者信息,那么就需要调用文章、评论、用户的接口。坏处造成服务的的维护困难,以及响应时间变长
。 原因: REST API通常由多个端点组成,每个端点代表一种资源。所以,当client需要多个资源是,它需要向REST
API发起多个请求,才能获取到所需要的数据。 REST API不好处理的问题 ,
比如确保client提供的参数是类型安全的,如何从代码生成API的文档等。 GraphQL解决的问题: 请求你的数据不多不少
:GraphQL查询总是能准确获得你想要的数据,不多不少,所以返回的结果是可预测的。 获取多个资源只用一个请求
:GraphQL查询不仅能够获得资源的属性,还能沿着资源间进一步查询,所以GraphQL可以通过一次请求就获取你应用所需的所有数据。
描述所有的可能类型系统: GraphQL
API基于类型和字段的方式进行组成,使用类型来保证应用只请求可能的类型,同时提供了清晰的辅助性错误信息。 使用你现有的数据和代码:
GraphQL让你的整个应用共享一套API,通过GraphQL API能够更好的利用你的现有数据和代码。GraphQL
引擎已经有多种语言实现,GraphQL不限于某一特定数据库,可以使用已经存在的数据、代码、甚至可以连接第三方的APIs。 API
演进无需划分版本: 给GraphQL API添加字段和类型而无需影响现有查询。老旧字段可以废弃,从工具中隐藏。