成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

再見 REST,你好 GraphQL

開發 前端
對于稍微復雜的關聯查詢,就顯得不太合適:如果設計一個 REST 接口,一般情況下會返回關聯表的全部字段,以滿足更多類似的查詢需求,如果設計多個細粒度接口,前端就需要查詢很多次,自己拼裝數據。

寫過前端的都知道,REST 風格的 API 適合簡單的增刪改查。對于稍微復雜的關聯查詢,就顯得不太合適:如果設計一個 REST 接口,一般情況下會返回關聯表的全部字段,以滿足更多類似的查詢需求,如果設計多個細粒度接口,前端就需要查詢很多次,自己拼裝數據。粗粒度的接口導致不必要的數據傳輸,細粒度的接口導致函數爆炸,你見過 JavaScript 的 Promise 滿天飛吧。

在此情景下 Facebook 的工程師于 2015 年開源了 GraphQL 規范,讓前端自己描述自己希望的數據形式,服務端則返回前端所描述的數據結構。簡單的來說,前端要啥,后端就返回啥,非常靈活。

什么是 GraphQL?

簡單來說,GraphQL 是一種面向數據的 API 查詢風格,把所有數據都視為已連接的圖形,客戶端能夠準確地獲得它需要的數據,沒有任何冗余,也讓 API 更容易地隨著時間推移而演進,還能用于構建強大的開發者工具。

比如,前端只需要 hero 的 name,那么后端就只返回這個 name,沒有冗余:

再比如:前端需要顯示作者的帖子信息,作者本人的信息,作者的關注者列表,假如是 REST,前端需要請求這三個接口,再組裝:

  • /user/獲取用戶(作者)詳細信息,可能是名稱。
  • /user//posts 獲取該用戶發布的帖子列表。
  • /user//followers 獲取用戶的關注者列表。

現在我們可以通過 GraphQL 的一次查詢拿到全部信息,無需從好幾個異步 API 里面來回找:

  1. query { 
  2.   User(id: '123') { 
  3.     name 
  4.     posts { 
  5.       title 
  6.     } 
  7.     followers { 
  8.       name 
  9.     } 
  10.   } 

簡潔明了,不是嗎?

GraphQL 帶來的改變

目前應用開發的主流就是前后端分離,前后端只通過 API 來交流,結構大概如下圖:

如果使用 GraphQL,那么后端將不再生產 API,而是將 Controller 層維護為 Resolver,和前端約定一套 Schema,這個 Schema 將用來生成接口文檔,前端直接通過 Schema 或生成的接口文檔來進行自己期望的請求。

經過幾年一線開發者的填坑,已經有一些不錯的awesome-graphql(https://github.com/chentsulin/awesome-graphql)用于開發與生產,很多語言也提供了對 GraphQL 的支持,比如 JavaScript/Nodejs、Java、PHP、Ruby、Python、Go、C# 等。

GraphQL 的使用趨勢

一些比較有名的公司正在轉換 REST API 到 GraphQL,比如 Twitter、IBM、Coursera、Airbnb、Facebook、Github、攜程等,特別是 Github,它的 v4 版外部 API 只使用 GraphQL。據一位在 Twitter 工作的大佬說硅谷不少一線二線的公司都在想辦法轉到 GraphQL 上,但是同時也說了 GraphQL 還需要時間發展,因為將它使用到生產環境需要前后端大量的重構,這無疑需要高層的推動和決心。

GraphQL 的局限性

對于簡單的應用程序而言,設置類型、查詢等可能會有些復雜,相比之下 REST 可以更輕松完成。

對于復雜的查詢,GraphQL 只需要一次接口請求,這樣雖然網絡層面的請求數被優化了,但是數據庫層面的查詢可一點都不少,數據庫查詢可能會成為性能瓶頸,還有很大的優化空間。

GraphQL 的優勢

檢索精確的數據,沒有冗余。通常,當數據需求發生變化時,您只需要修改查詢,并且不需要太多更改,從而提高前后端的開發效率,可以快速進行產品迭代。

最后的話

 

GraphQL 已經被各種體量的團隊所使用,在不同的環境、不同的語言下,用于增強移動應用、網站和 API。如果你已經厭倦了 REST API,現在是時候學習一下 GraphQL 了。關注公眾號「Python七號」,學習更多技術干貨。

 

責任編輯:武曉燕 來源: Python七號
相關推薦

2015-03-16 11:09:28

MongoDBPostgreSQL數據遷移

2012-08-01 09:50:09

HotmailOutlook微軟

2021-01-13 11:13:46

ExcelPandas代碼

2019-02-01 10:35:33

PythonGo語言編程語言

2021-07-27 05:56:53

CrocFTPSFTP

2018-01-02 08:40:19

云安全云遷移數據泄露

2023-11-28 17:24:45

2009-03-30 08:44:22

微軟Windows 7操作系統

2020-09-27 11:15:37

可視化PandasPython

2023-11-09 09:13:48

GraphQLAPI 架構

2011-01-07 18:05:37

QQ騰訊移動互聯網

2024-04-16 12:00:14

API系統

2022-05-06 09:52:17

REST接口API

2014-11-27 14:26:46

蘋果iPhone停產

2021-06-02 22:25:26

2G5G運營商

2023-04-10 07:40:36

GraphQLRest通信模式

2024-06-24 00:20:00

API應用程序接口

2023-03-10 15:03:37

Web 應用程序API開發

2023-03-16 18:04:00

APIWeb 應用程序開發

2022-08-02 19:03:19

RestAPI集成
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 97精品国产97久久久久久免费 | 国产欧美精品区一区二区三区 | 91偷拍精品一区二区三区 | 亚洲精品av在线 | 日韩午夜精品 | 日韩视频在线播放 | 国产精品自产拍 | 91视视频在线观看入口直接观看 | 男女视频在线观看 | 99精品欧美一区二区蜜桃免费 | 神马福利 | 日本三级播放 | 久久不射网 | 午夜激情免费视频 | 日韩av一二三区 | 国产精品久久久久久久久久免费看 | 99久久精品国产麻豆演员表 | 中文字幕中文字幕 | 欧美嘿咻 | 亚洲精品中文字幕 | 久久精品中文字幕 | 欧美a区| 日韩在线第一 | 精品二| 四虎永久免费地址 | 亚洲网站免费看 | 国产精品欧美日韩 | 国产精品99免费视频 | 久久久网| 91porn在线 | 国产精品成人一区二区三区吃奶 | 日本黄色不卡视频 | 激情毛片 | www久久久| 狠狠色网 | 日本午夜免费福利视频 | 久久久久久久久99 | 亚洲精品电影网在线观看 | 国产一区视频在线 | 成人av高清在线观看 | 日韩乱码av |