GraphQL:为您的 Web 应用程序提供了什么

什么是 GraphQL

GraphQL 是一种用于 API 的查询语言,旨在解决在 RESTful API 中存在的一些问题。GraphQL 最初由 Facebook 在 2012 年开发,并于 2015 年向公众开放。GraphQL 允许客户端明确请求其需要的数据,并返回与之匹配的精确结果。

GraphQL 的核心原则之一是“请求你需要的内容,而不是固定的内容”,这意味着客户端可以通过 GraphQL 查询语句精确地指定要返回的数据,而不会得到不需要的信息。例如,在查询电影详情时,客户端只需要请求电影名称、主演和描述等信息,而不需要获取与电影无关的额外信息。

GraphQL 的优点

简化客户端和服务器的通信

在传统的 RESTful API 中,客户端必须向服务器发送多个请求来获取其需要的所有数据。这会导致网络延迟和性能问题。GraphQL 的查询语言允许客户端一次性请求其需要的所有数据,服务器会返回与查询所需匹配的精确结果。这样可以减少网络延迟和提高性能。

精确控制数据

在 RESTful API 中,服务器端返回的数据通常是预定义的,甚至可能包含客户端根本不需要的数据。使用 GraphQL,客户端可以明确指定要返回的数据,并避免得到不需要的信息。这可以节省带宽和减少客户端的处理工作。

更好的开发体验

GraphQL 具有强类型和明确的 API 契约,使前端和后端团队可以协作开发 API。这可以减少开发时间,并提高代码的可读性和可维护性。

如何使用 GraphQL

定义 GraphQL Schema

GraphQL Schema 定义了可用字段和类型的集合。它是定义 GraphQL API 的起点。Schema 可以使用 GraphQL SDL (Schema Definition Language) 进行定义,也可以使用编程语言(例如 JavaScript)进行编写。

---- ----- -
  --- ---
  ------ -------
  --------- -------
  ------- ---------
  ------------ -------
-

---- ----- -
  --------- ----- -----
  ------------------- --------- --------
-

上述代码定义了两种类型:Movie 和 Query。Movie 类型包含电影详细信息,Query 类型中包含查询字段,客户端可以调用这些字段获取有关电影的数据。

处理 GraphQL 查询

GraphQL 提供了一个标准规范来处理查询语句,可以使用现有的工具和框架进行实现。GraphQL 的实现通常包括三个主要组件:Schema、Resolver 和数据源。

  • Schema:定义可用的字段和类型。
  • Resolver:根据查询和变量返回数据。
  • 数据源:从数据库、API 或其他第三方服务中获取数据。

使用 Node.js 和 Express.js 构建一个 GraphQL API:

----- ------- - -------------------
----- - ----------- - - ---------------------------
----- - ----------- - - -------------------

-- -- ------- ------
----- ------ - -------------
  ---- ----- -
    --- ---
    ------ -------
    --------- -------
    ------- ---------
    ------------ -------
  -

  ---- ----- -
    --------- ----- -----
    ------------------- --------- --------
  -
---

----- ------ - -
  -
    --- --
    ------ ---- --------- ------------
    --------- ------ ----------
    ------- ----- --------- ------- --------- ---- ---------
    ------------ ---- ---------- --- ---- ---- - ------ -- ------ ------- ------ --- -------- ---------- ------- ---- -- ------ ---------
  --
  -
    --- --
    ------ ---- -----------
    --------- -------- ---- ---------
    ------- -------- -------- --- -------- ------ -------
    ------------ ---- ----- --------- -- -- --------- ----- ------- --------- ------- -- --- ----------- ------ -- --- --------- -----
  -
--

-- -----
----- -------- - -- -- ----------------- -- -------- --- --------------
----- ------------ - ----- -- ------------------- -- ---------------------------------------------------------

----- ---- - -
  ------ -- -- -- -- -------------
  ------------- -- ----- -- -- -------------------
--

----- --- - ----------

------------------- -------------
  -------
  ---------- -----
  --------- ----
----

---------------- -- -- -
  ---------------------- -- ---- -------
---

客户端可以向 GraphQL API 发送查询请求,并获取有关电影的数据。

----- -
  --------- -- -
    -----
    --------
    ------
    -----------
  -
-

----- -
  ------------------- ------------ -
    -----
    --------
    ------
    -----------
  -
-

结论

GraphQL 已被证明是一种强大的 API 查询语言和工具。它可以帮助您更好地控制数据,提高性能,并提供更好的开发体验。尝试使用 GraphQL 来构建您的下一个 Web 应用程序,看看它如何改进您的开发流程和用户体验。

来源:JavaScript中文网 ,转载请注明来源 本文地址:https://www.javascriptcn.com/post/67297b0d2e7021665e24a20c