搜尋
首頁web前端js教程GraphQL 轉變 API 開發

GraphQL Transforming API Development

簡介

現代 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

這是一個實際的實作:

  1. 安裝依賴項:npm install @apollo/server graphql

  2. 定義您的架構:

<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>
  1. 新增解析器:
<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>
  1. 啟動伺服器:
<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 整合到您的開發堆疊中的理想時機。

參考文獻

  1. GraphQL 官方文件
  2. Apollo GraphQL 平台
  3. Netflix 工程 - GraphQL Federation
  4. GitHub GraphQL API 案例研究
  5. GraphQL 最佳實踐

作者簡介

Ivan Duarte 是一名自由後端開發人員,熱衷於 Web 開發和人工智慧。

訂閱我們的電子報

直接在收件匣中閱讀 ByteUp 的文章。立即訂閱!

以上是GraphQL 轉變 API 開發的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
JavaScript數據類型:瀏覽器和nodejs之間是否有區別?JavaScript數據類型:瀏覽器和nodejs之間是否有區別?May 14, 2025 am 12:15 AM

JavaScript核心數據類型在瀏覽器和Node.js中一致,但處理方式和額外類型有所不同。 1)全局對像在瀏覽器中為window,在Node.js中為global。 2)Node.js獨有Buffer對象,用於處理二進制數據。 3)性能和時間處理在兩者間也有差異,需根據環境調整代碼。

JavaScript評論:使用//和 / * * / * / * /JavaScript評論:使用//和 / * * / * / * /May 13, 2025 pm 03:49 PM

JavaScriptusestwotypesofcomments:single-line(//)andmulti-line(//).1)Use//forquicknotesorsingle-lineexplanations.2)Use//forlongerexplanationsorcommentingoutblocksofcode.Commentsshouldexplainthe'why',notthe'what',andbeplacedabovetherelevantcodeforclari

Python vs. JavaScript:開發人員的比較分析Python vs. JavaScript:開發人員的比較分析May 09, 2025 am 12:22 AM

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

Python vs. JavaScript:選擇合適的工具Python vs. JavaScript:選擇合適的工具May 08, 2025 am 12:10 AM

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript:了解每個的優勢Python和JavaScript:了解每個的優勢May 06, 2025 am 12:15 AM

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

JavaScript的核心:它是在C還是C上構建的?JavaScript的核心:它是在C還是C上構建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

Python vs. JavaScript:您應該學到哪種語言?Python vs. JavaScript:您應該學到哪種語言?May 03, 2025 am 12:10 AM

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 Mac版

SublimeText3 Mac版

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