簡介
現代 Web 應用程式需要有效率、靈活的資料擷取。 GraphQL 是一種徹底改變 API 開發的查詢語言,可以滿足這項需求。自 Facebook 2015 年首次亮相以來,GraphQL 的廣泛採用證明了其價值超越了轉瞬即逝的趨勢。
理解 GraphQL 的核心原則
GraphQL 是一種 API 查詢語言和執行階段。與伺服器決定回應結構的傳統 REST API 不同,GraphQL 允許客戶端透過單一請求請求精確的資料。這解決了許多現代應用程式開發挑戰。
想像一下一位知識淵博的圖書館員可以快速找到任何一本書。您無需搜尋多個書架(多個 API 端點),只需提供詳細的請求,圖書館員就會返回您所需要的內容 — 不多也不少。
GraphQL 的模式驅動性質創造了清晰的客戶端-伺服器契約。 每個 GraphQL 服務都定義資料類型,在執行之前啟用模式驗證,以獲得可預測的一致回應。
技術基礎
GraphQL 使用三個主要操作:查詢(資料檢索)、突變(資料修改)和訂閱(即時更新)。 強大的類型系統支援每個操作,定義 API 功能。
<code>type User { id: ID! name: String! email: String! posts: [Post!]! friends: [User!]! } type Post { id: ID! title: String! content: String! author: User! comments: [Comment!]! createdAt: String! } type Comment { id: ID! text: String! author: User! post: Post! }</code>
架構定義關係,允許在單一查詢中進行巢狀資料檢索(例如,使用者的貼文或朋友)。
解析器:GraphQL 的核心
GraphQL 的強大之處在於它的解析器函數。這些函數檢索每個架構欄位的資料。 解析器可以從資料庫取得資料、呼叫其他 API 或執行複雜的計算,所有這些對客戶端都是透明的。
解析器範例(使用 Prisma)
以下是如何使用 Prisma 實作解析器來取得使用者的貼文和好友:
<code>const resolvers = { User: { async posts(parent, args, context) { const posts = await context.prisma.post.findMany({ where: { authorId: parent.id }, orderBy: { createdAt: 'desc' }, }); return posts; }, async friends(parent, args, context) { const friends = await context.prisma.user.findMany({ where: { id: { in: parent.friendIds }, }, }); return friends; }, }, };</code>
這些解析器僅在請求時有效地取得資料。
API 開發的演變
還記得純 REST API 的日子嗎?多個端點傳回固定的資料結構。 這適用於簡單的應用程序,但隨著複雜性的增加而變得笨拙。移動和 Web 用戶端需要不同的數據,導致多次 API 呼叫。
解 N 1 查詢問題
N 1 查詢問題(透過多個資料庫查詢取得相關資料)是一個重大的 API 挑戰。 GraphQL 使用 DataLoader 和類似工具批次和最佳化查詢的能力改變了效能。
實作範例(DataLoader):
取得相關數據常常會導致N 1 問題。 GraphQL 透過 DataLoader、批次和快取資料庫呼叫等工具解決了這個問題:
<code>type User { id: ID! name: String! email: String! posts: [Post!]! friends: [User!]! } type Post { id: ID! title: String! content: String! author: User! comments: [Comment!]! createdAt: String! } type Comment { id: ID! text: String! author: User! post: Post! }</code>
這可以透過批次請求最大限度地減少資料庫查詢,從而顯著提高效能。
真實世界的成功故事
- Netflix 的動態使用者介面: Netflix 使用 GraphQL 跨裝置實作動態 UI,根據上下文取得精確的節目資訊。
- GitHub 的 API 革命: GitHub 的 v4 API 切換到 GraphQL,減少了響應負載大小並提高了開發人員的靈活性。
使用 Node.js 和 Apollo Server 實作 GraphQL
這是一個實際的實作:
-
安裝依賴項:
npm install @apollo/server graphql
-
定義您的架構:
<code>const resolvers = { User: { async posts(parent, args, context) { const posts = await context.prisma.post.findMany({ where: { authorId: parent.id }, orderBy: { createdAt: 'desc' }, }); return posts; }, async friends(parent, args, context) { const friends = await context.prisma.user.findMany({ where: { id: { in: parent.friendIds }, }, }); return friends; }, }, };</code>
- 新增解析器:
<code>const DataLoader = require('dataloader'); const userLoader = new DataLoader(async (userIds) => { const users = await prisma.user.findMany({ where: { id: { in: userIds }, }, }); return userIds.map(id => users.find(user => user.id === id)); }); const resolvers = { Post: { async author(parent) { return userLoader.load(parent.authorId); }, }, };</code>
- 啟動伺服器:
<code>const typeDefs = `#graphql type Query { hello: String }`;</code>
透過欄位選擇進行效能最佳化 (Prisma)
GraphQL 根據請求欄位最佳化資料庫查詢:
<code>const resolvers = { Query: { hello: () => "Hello, GraphQL!", }, };</code>
這只檢索必要的數據,從而減少開銷。
GraphQL 的未來
- Apollo Federation: 允許跨多個服務拆分 GraphQL 模式,同時提供統一的 API。
-
具有訂閱功能的即時功能:支援即時通知和協作應用程式的即時更新。 使用
graphql-subscriptions
的範例:
<code>const { ApolloServer } = require('@apollo/server'); const server = new ApolloServer({ typeDefs, resolvers }); server.listen().then(({ url }) => { console.log(`? Server ready at ${url}`); });</code>
GraphQL 入門
GraphQL 的逐步採用是關鍵優勢。 首先將其與現有 REST API 一起實現,也許作為代理層。這可以在實現優勢的同時最大限度地降低風險。
結論
GraphQL 是資料取得和客戶端-伺服器通訊方面的範式轉移。隨著應用程式的成長,其靈活性和效率變得越來越重要。 考慮使用 GraphQL 來提高效能、開發人員體驗和使用者滿意度。從小實驗開始,逐步擴大用途。蓬勃發展的社區和生態系統現在是將 GraphQL 整合到您的開發堆疊中的理想時機。
參考文獻
- GraphQL 官方文件
- Apollo GraphQL 平台
- Netflix 工程 - GraphQL Federation
- GitHub GraphQL API 案例研究
- GraphQL 最佳實踐
作者簡介
Ivan Duarte 是一名自由後端開發人員,熱衷於 Web 開發和人工智慧。
訂閱我們的電子報
直接在收件匣中閱讀 ByteUp 的文章。立即訂閱!
以上是GraphQL 轉變 API 開發的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript字符串替換方法詳解及常見問題解答 本文將探討兩種在JavaScript中替換字符串字符的方法:在JavaScript代碼內部替換和在網頁HTML內部替換。 在JavaScript代碼內部替換字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 該方法僅替換第一個匹配項。要替換所有匹配項,需使用正則表達式並添加全局標誌g: str = str.replace(/fi

本教程向您展示瞭如何將自定義的Google搜索API集成到您的博客或網站中,提供了比標準WordPress主題搜索功能更精緻的搜索體驗。 令人驚訝的是簡單!您將能夠將搜索限制為Y

因此,在這裡,您準備好了解所有稱為Ajax的東西。但是,到底是什麼? AJAX一詞是指用於創建動態,交互式Web內容的一系列寬鬆的技術。 Ajax一詞,最初由Jesse J創造

本文系列在2017年中期進行了最新信息和新示例。 在此JSON示例中,我們將研究如何使用JSON格式將簡單值存儲在文件中。 使用鍵值對符號,我們可以存儲任何類型的

利用輕鬆的網頁佈局:8 ESTISSEL插件jQuery大大簡化了網頁佈局。 本文重點介紹了簡化該過程的八個功能強大的JQuery插件,對於手動網站創建特別有用

核心要點 JavaScript 中的 this 通常指代“擁有”該方法的對象,但具體取決於函數的調用方式。 沒有當前對象時,this 指代全局對象。在 Web 瀏覽器中,它由 window 表示。 調用函數時,this 保持全局對象;但調用對象構造函數或其任何方法時,this 指代對象的實例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。這些方法使用給定的 this 值和參數調用函數。 JavaScript 是一門優秀的編程語言。幾年前,這句話可

jQuery是一個很棒的JavaScript框架。但是,與任何圖書館一樣,有時有必要在引擎蓋下發現發生了什麼。也許是因為您正在追踪一個錯誤,或者只是對jQuery如何實現特定UI感到好奇

該帖子編寫了有用的作弊表,參考指南,快速食譜以及用於Android,BlackBerry和iPhone應用程序開發的代碼片段。 沒有開發人員應該沒有他們! 觸摸手勢參考指南(PDF)是Desig的寶貴資源


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

MantisBT
Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)