React+Redux 实现 SPA 数据缓存的最佳实践

前言

在开发单页应用(SPA)时,数据缓存是一个非常重要的问题。一方面,数据缓存可以提高应用的性能,减少不必要的网络请求,另一方面,数据缓存也会带来一些问题,例如缓存数据过期、数据一致性等问题。本文将介绍如何使用 React 和 Redux 实现 SPA 数据缓存的最佳实践。

数据缓存的实现

Redux 中间件

在 Redux 中,我们可以使用中间件来实现数据缓存。中间件是 Redux 提供的一种扩展机制,可以在 action 被发起之后,到达 reducer 之前执行一些额外的逻辑。我们可以在中间件中实现数据缓存的逻辑。

下面是一个简单的缓存中间件的实现:

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

这个中间件的作用是:对于每个带有 cacheKeycacheTime 的 action,将其返回的数据缓存在本地存储中。对于每个带有 cacheKey 的 action,如果本地存储中有缓存数据,并且缓存未过期,则直接返回缓存数据,不再发起网络请求。

缓存键的生成

在实际的开发中,我们需要为每个需要缓存的 action 生成一个唯一的缓存键。一种简单的方式是使用 action 的 type 和 payload 来生成缓存键。例如,我们可以将 getUsers 这个 action 的缓存键定义为 users_${JSON.stringify(payload)}

在实际的开发中,我们可能需要在多个地方使用同一个缓存键,因此最好将缓存键的生成逻辑封装成一个函数,并在需要使用的地方调用。

缓存过期时间的设置

在实际的开发中,我们需要为每个缓存设置一个过期时间。过期时间可以是一个固定的时间间隔,也可以是一个动态的时间间隔。例如,我们可以将 getUsers 这个 action 的缓存过期时间设置为 5 分钟:

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

在实际的开发中,我们需要根据不同的业务场景设置不同的缓存过期时间。

缓存的清理

在实际的开发中,我们还需要定期清理过期的缓存。一种简单的方式是在每次发起 action 时,遍历本地存储中的所有缓存,将过期的缓存清理掉。例如,我们可以在中间件中添加清理缓存的逻辑:

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

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

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

在实际的开发中,我们需要根据缓存的使用情况和缓存的大小,定期清理过期的缓存,避免缓存占用过多的存储空间。

示例代码

下面是一个使用 React 和 Redux 实现数据缓存的示例代码:

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

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

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

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

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

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

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

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

在上面的代码中,我们定义了一个 getUsers 的 action,将其返回的数据缓存到本地存储中。在 UserList 组件中,我们使用 useSelector 从 Redux 中获取缓存数据。

总结

在开发 SPA 时,数据缓存是一个非常重要的问题。使用 Redux 中间件可以很方便地实现数据缓存的逻辑。在实际的开发中,我们需要根据不同的业务场景设置不同的缓存过期时间,并定期清理过期的缓存。

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