GraphQL 的本地状态管理技巧

AI 编程助手,豆包旗下的编程助手,提供智能补全、智能预测、智能问答等能力,节省开发时间,释放脑海中的创造力,支持 VSCode,点击体验 AI

GraphQL 是一种用于 API 的查询语言,它能够提供更高效、强大和灵活的数据查询。然而,当我们在前端应用中使用 GraphQL 时,我们通常还需要对数据进行本地状态管理。在这篇文章中,我将分享一些 GraphQL 的本地状态管理技巧,帮助你更好地管理和使用 GraphQL 查询结果。

为什么需要本地状态管理

首先,让我们看一下为什么我们需要本地状态管理。使用 GraphQL 查询 API 可以很容易地获取数据,也可以控制数据的粒度。但与此同时,我们通常需要对这些查询结果进行一些操作,比如过滤、排序、分页等。这时,我们就需要将这些查询结果存储在本地,以便更好地管理和操作它们。

另外,当我们需要在应用中进行一些交互时,本地状态管理也非常有用。比如说,在一个电商应用中,我们需要将一组商品添加到购物车中,这时就需要将这些商品的信息存储在本地。本地状态管理可以帮助我们处理这些场景,让应用更加流畅和交互友好。

下面,我将介绍一些 GraphQL 的本地状态管理技巧,帮助你更好地管理和使用 GraphQL 查询结果。

使用 Apollo Client

Apollo Client 是一个用于 JavaScript 的 GraphQL 客户端,提供了本地状态管理的能力。它可以帮助我们管理应用中的 GraphQL 查询结果,并提供一些方便的 API 来进行查询、数据变更等操作。

首先,我们需要创建一个 Apollo Client 实例,并将它传递给应用的根组件。这样,我们就可以在整个应用中使用这个实例,并将查询结果存储在它的缓存中。

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

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

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

接下来,我们可以使用 Apollo Client 提供的 useQueryuseMutation 等钩子来进行查询、数据变更等操作。这些钩子会从 Apollo Client 的缓存中获取数据,并提供方便的 API 来进行数据操作。比如说,下面的代码展示了如何使用 useQuery 钩子来获取一个文章列表:

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

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

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

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

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

在这个例子中,我们使用 useQuery 钩子来获取文章列表。useQuery 钩子会先从 Apollo Client 的缓存中获取数据。如果没有找到缓存数据,它就会向后端发送一个 GraphQL 查询,并将查询结果存储在缓存中。我们可以在组件中直接访问查询结果,并进行渲染操作。

缓存数据正规化

当我们使用 Apollo Client 管理查询结果时,它会将查询结果存储在一个缓存中。这个缓存类似于一个数据库,它会将查询结果按照 id 进行索引,并将查询结果正规化存储。这样,我们就可以在查询结果中直接进行访问,而不需要深入嵌套的查询结果中获取数据。

比如说,下面的代码展示了一个包含文章和评论的查询结果。我们可以看到,缓存中将文章和评论分别存储在不同的对象中,按照 id 进行索引。

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

这种缓存数据正规化带来了很多好处。首先,它提高了访问缓存数据的效率。我们可以直接访问缓存对象,并通过 id 获取具体的数据,而不需要逐层深入查询结果中。

此外,缓存数据正规化还可以帮助我们进行数据更新。当我们对查询结果进行更新时,Apollo Client 会自动更新缓存中对应的数据,并使得我们可以在组件中直接访问最新的数据。比如说,下面的代码展示了如何使用 useMutation 钩子来添加一个评论。

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

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

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

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

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

在这个例子中,我们使用 useMutation 钩子来添加一个评论。useMutation 钩子会调用后端 GraphQL API,然后将查询结果存储在缓存中。我们通过 cache.modify API 来更新缓存数据。这里,我们通过 cache.identify API 来获取文章对象的 id,并通过 cache.writeFragment API 来添加新的评论数据。这样,我们就可以在组件中直接访问最新的评论数据。

使用 DataContext

除了使用 Apollo Client 进行本地状态管理之外,我们还可以使用 React 的 useContext 钩子和 createContext API 来实现本地状态管理。这种方式的好处是它更加轻量,并且更适合一些简单的应用场景。

首先,我们需要使用 createContext API 来创建一个 DataContext,用于存储应用中的数据。然后,我们可以通过 useContext 钩子来访问 DataContext 中存储的数据。

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

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

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

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

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

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

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

在这个例子中,我们创建了一个 DataContext,用于存储数据。我们可以通过 useContext(DataContext) 钩子来访问 DataContext 中存储的数据。在 ChildComponent 组件中,我们可以通过 setData 方法来更新数据,并在组件中渲染最新的数据。

结论

GraphQL 是一种强大的 API 查询语言,在前端应用中使用 GraphQL 可以方便地获取数据和控制数据的粒度。然而,当我们需要对查询结果进行操作时,本地状态管理就非常重要了。在本文中,我们介绍了一些 GraphQL 的本地状态管理技巧,帮助你更好地管理和使用 GraphQL 查询结果。当然,这些技巧只是冰山一角,你可以深入学习 GraphQL 和 Apollo Client,并掌握更多的技能。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/671b1b459babaf620fa7fd3a


猜你喜欢

  • GraphQL 与 RESTful API 的比较:优缺点

    简介 RESTful API 和 GraphQL 都是前端开发中常用的 API 架构,它们都可以通过 HTTP 协议来传递数据,但是它们有着不同的设计思想和实现方式。

    16 天前
  • Fastify 框架下如何实现 WebSocket 通信

    WebSocket 已成为现代 Web 应用程序中实时通信的主要方式。它提供了一种在客户端和服务器之间进行双向通信的机制,而无需使用轮询或长轮询技术。Fastify 是一个快速且低开销的 Node.j...

    16 天前
  • 减少 Lambda 执行时间的方法

    AWS Lambda 是一款非常受欢迎的 Serverless 服务,但是在使用 Lambda 时,我们经常会发现其执行时间相对较长,这不仅会影响程序的性能,还会增加其他相关的费用。

    16 天前
  • 无障碍技术 | 使用无障碍技术打造更好的用户体验

    无障碍技术是指使得应用程序在任何情况下都可用,尤其是在对残疾人、老年人、颜色盲、低视力和聋哑人士等人士进行无障碍设计时,更为重要。这是一种为所有人提供可用性的设计方法,以提高访问良好性,并通过前端技术...

    16 天前
  • MongoDB 与 Hadoop 处理大数据实践

    随着互联网和物联网的普及,数据量不断增长,传统的数据存储和处理方式已经无法胜任处理大量数据的任务。此时,大数据处理技术应运而生。MongoDB 和 Hadoop 是两个常用的大数据处理工具,今天我们来...

    16 天前
  • Babel 6 已经发布,这些新功能你应该学习

    Babel 是一个用于将 ES6+ 代码转换为向后兼容的 JavaScript 代码的工具。它是前端开发中的重要工具之一,而最近发布的 Babel 6 带来了很多有趣的新功能。

    16 天前
  • TypeScript 中的接口和抽象类

    在 TypeScript 中,接口和抽象类都是非常常用的定义类型、组织代码的工具。这个文章将详细介绍它们的区别和应用场景。 TypeScript 接口 接口(Interface)是 TypeScrip...

    16 天前
  • 如何用 Chai 进行数据验证和断言?

    在前端开发中,我们常常需要对数据进行验证和断言,以保证代码的正确性和稳定性。Chai 是一个流行的 JavaScript 断言库,它可以帮助我们轻松地进行数据验证和断言。

    16 天前
  • 如何在 Jest 中模拟 Redux store

    Redux 是一种流行的状态管理库,它被广泛应用于前端开发中。当我们使用 Redux 时,我们通常需要编写一些单元测试来确保我们的应用程序的正确性。然而,当我们在 Jest 中编写测试时,我们可能需要...

    16 天前
  • 使用 Server-Sent Events 实现实时数据推送

    引言 在现代 Web 应用程序开发中,实时数据推送变得越来越重要。在过去,开发人员不得不通过 AJAX 长轮询或 WebSockets 来实现实时通信。不过, 这些方法对于实现简单的实时通信来说过于繁...

    16 天前
  • 学习 RxJS 的 10 个习惯,快速提高编程效率

    RxJS 是一款强大且逐渐流行的 JavaScript 库,它是 Reactive Extensions 的 JavaScript 实现,可以提供流式数据操作。学习 RxJS 可以帮助前端开发者更加高...

    16 天前
  • 如何在 Web Components 中使用路由

    Web 组件(Web Components)是用于创建可重用组件的浏览器 API,可帮助以可组合和可重用的方式构建现代 Web 应用程序,其中包含自定义元素、影子 DOM 和 HTML 模板。

    16 天前
  • 使用 Tailwind CSS 将 Bootstrap 退役的四个原因

    前言 在前端开发领域中,使用框架是提高开发效率的常用手段。Bootstrap 作为前端开发的经典框架,在过去的几年中被广泛使用。然而,近期出现了一个新的框架——Tailwind CSS,许多开发者甚至...

    16 天前
  • 使用 Hapi.js 需要注意的 HTTPS 协议问题

    Hapi.js 是一个轻量级的 Node.js 框架,可用于构建快速、可扩展的 Web 应用程序。通常,Web 应用程序需要保护其中的敏感信息,如登录凭据、支付信息等。

    16 天前
  • MongoDB 与 Redis 结合使用指南

    在开发 web 应用程序时,处理数据是一个非常重要的任务。数据库是存储和管理数据的重要组件之一。现在的 web 应用程序越来越复杂,需要更快的数据检索、处理和分析能力。

    17 天前
  • 如何在 ES8 中使用展开操作符组合对象

    在前端开发中,我们经常需要组合两个或多个对象。在 ES8 中,我们可以使用展开操作符来快速而方便地完成这个任务。本文将详细介绍如何使用展开操作符来组合对象,在深度和学习方面提供指导意义,并包含相应示例...

    17 天前
  • Mongoose 之 Error: pool destroyed 解决方法

    Mongoose 是一个 Node.js 上面的 MongoDB 对象模型工具,它可以让我们使用 JavaScript 的方式来操作 MongoDB 数据库,而 Mongoose 也是目前为止最流行的...

    17 天前
  • 如何处理 GraphQL 中的 SQL 注入

    GraphQL 是一个强大的查询语言,它允许前端开发者轻松地从后端 API 中提取需要的数据。然而,GraphQL 在数据查询和传输的过程中,也存在一些安全性问题,其中较为严重的就是 SQL 注入。

    17 天前
  • Node.js性能优化的最佳实践

    随着应用程序规模的不断扩大,Node.js 的性能已经成为许多应用程序开发者的主要关注点之一。为了保证应用程序的速度和可靠性,需要实施一些 Node.js 性能优化的最佳实践。

    17 天前
  • 使用 Web Components 时常见的警告和解决方法

    Web Components 是一种用于扩展现有 HTML 元素的技术。它由三个主要技术组成:自定义元素、Shadow DOM 和 HTML 模板。使用它们可以创建自定义的 HTML 元素,使其具备更...

    17 天前

相关推荐

    暂无文章