npm 包 dva-model-persist 使用教程

背景

对于前端开发者来说,很多时候我们需要对应用状态进行持久化,以便实现状态在应用运行过程中的顺畅转换。其中,dva 是一款优秀的前端框架,然而 dva 的数据流方案只在内存中保存了状态,没有做持久化,因此需要开发者自己考虑数据状态的持久化实现。

在这里我们介绍一个方便易用的 npm 包 dva-model-persist,该包能够将 dva model 中的状态进行持久化,并且在 dva model 更新时自动更新持久化状态。下文将为大家详细介绍该包的使用方法。

安装

dva-model-persist 可以通过 npm 安装:

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

使用

API 介绍

dva-model-persist 暴露了三个 API:

  1. createPersistedReducer

该 API 接受一个可持久化的角色和一个根 reducer,在角色变化时,它会将之前角色的状态读取出来并恢复。

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

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

----- ------------- - --------------
------ ------- ------------------------------------- ------------
  1. persistStore

该 API 接受一个 Redux store 实例并且返回一个persistor对象,用于观察 store 并将其保存本地。在应用挂载之前调用这个函数并订阅 persitor 初始化状态。当 persitor 准备好之后,将显示一个回调函数。

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

----- ----- - ---------------------
----- --------- - ------------------- ----- -- -- -
  ------------------------ -----------
---
  1. purgeStoredState

该 API 可以清空本地存储的状态。

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

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

示例

我们以一个简单的 TodoList 应用来演示 dva-model-persist 的使用。首先我们需要安装 dva 以及 dva-model-persist:

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

然后定义一个存储 TodoList 状态的 model:

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

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

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

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

这里我们调用了 createPersistedReducerAPI,设置了一个名为 app 的角色,然后将应用的业务逻辑写在了 appReducer 中。同时,使用 ...state 的方式简化 state 更新,这是 es6 语法和 redux 库本身的特性。

接下来,我们将其与 dva 框架集成:

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

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

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

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

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

-- ------

这里我们将 appReducer 传入 dva 的 model 方法中,然后调用 persistStoreAPI 创建一个 persistor。在初始化 App UI 之前,我们需要调用 persistor 的 initialize 方法来恢复 store 的旧状态。在回调 onRehydrateComplete 中,我们将完全初始化的 app 注入了 Router 组件,然后调用 app.start 方法启动 dva 应用。

最后,我们在 React 组件中调用 model 中定义的方法来更新 todoList 状态:

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

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

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

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

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

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

到这里,我们已经可以更新 todoList 状态并且将其持久化到 localStorage 中了。同时,dva-model-persist 会在每次更新 model 后更新持久化状态。这样,我们就完成了 TodoList 应用的开发。

总结

dva-model-persist 是一个简单而实用的 npm 包,可以帮助前端开发者便捷的将应用状态保存到本地持久化存储并从本地读取。虽然我们的例子使用了 dva 作为状态管理库,但是 dva-model-persist 也可以与其他类 React 应用的状态管理库如 redux 集成。希望本文能够帮助读者高效的开发实现带有持久化状态的 React 应用。

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


猜你喜欢

  • npm 包 topojson-osm-fetch 使用教程

    前言 在今天的前端开发中,地图是非常常用的一类组件。然而,在处理地图数据时,我们经常需要使用到 topjson 格式的数据,但是如何获取这样的数据并进行处理却很多人不清楚。

    3 年前
  • npm 包 @ycs/auth 使用教程

    前置知识 Node.js 环境(推荐使用最新版) npm 包管理器(推荐使用最新版) @ycs/auth 简介 @ycs/auth 是一个提供身份验证的 npm 包,它可以在前端和后端同时使用。

    3 年前
  • npm 包 joaodfmota-serverless-plugin-typescript 使用教程

    简介 joaodfmota-serverless-plugin-typescript 是一个 npm 包,在使用 AWS Lambda 函数时,让开发者使用 TypeScript 进行开发,从而提高开...

    3 年前
  • npm 包 react-native-page-links 使用教程

    React Native 是 Facebook 推出的一种开源的跨平台移动应用开发框架。它基于 JavaScript 语言和 React 库(一个用于创建 UI 的JavaScript库)构建。

    3 年前
  • npm包 v-thread 使用教程

    什么是 v-thread? v-thread 是一个基于 Vue.js 的多线程处理库。它允许你在浏览器中使用 Web Workers,并在主线程和子线程之间进行通信。

    3 年前
  • npm 包 simple-console-npm 使用教程

    一、简介 simple-console-npm 是一个基于 Node.js 和 npm 的工具包,提供了一种集成式的控制台操作方式,用户可以在控制台中输入指令,执行相应的操作。

    3 年前
  • npm 包 @khayong/mantra-core 使用教程

    作为前端开发人员,我们经常需要使用各种 npm 包来辅助我们完成项目中的各种功能。在这篇文章中,我们将要介绍一个名为 @khayong/mantra-core 的 npm 包,它是基于 React 的...

    3 年前
  • npm 包 ethertron 使用教程

    什么是 ethertron ethertron 是一个可用于将以太坊区块链交互添加到您的 Web 应用程序中的 npm 包。 ethertron 通过提供基于以太坊区块链的智能合约的交互功能,可以轻松...

    3 年前
  • npm 包 gulu-demo-dawson 使用教程

    前言 gulu-demo-dawson 是一个完整的前端 UI 组件库,可轻松在您的项目中使用。该组件库是由组件化思维驱动的,使得组件更为通用化,同时也更加容易去维护和升级。

    3 年前
  • npm 包 tcole98-palindrome 使用教程

    前言 随着前端技术的发展,越来越多的 npm 包可以简单高效地完成某些功能。tcole98-palindrome 就是一个很有用的 npm 包,它可以判断一个字符串是否为回文字符串。

    3 年前
  • npm 包 coinmarketcap-icons 使用教程

    简述 coinmarketcap-icons 是一个 npm 包,它提供了加密货币市场的图标。这些图标可以方便地用于前端项目中,让项目得到更好的展示效果。 本文将介绍 npm 包 coinmarket...

    3 年前
  • npm 包 eth-mine-when-need 使用教程

    简介 eth-mine-when-need 是一个基于 web3.js 的以太坊挖矿工具包,可用于在需要 ETH 或 ERC20 token 交易时临时开启挖矿以顺利完成交易。

    3 年前
  • npm 包 mcls-lib 使用教程

    什么是 mcls-lib? mcls-lib 是一个可以帮助开发者在应用程序中实现 Material Design 规范的 JavaScript 库。它封装了大量的 Material Design 样...

    3 年前
  • npm包pubt使用教程

    1. 简介 Pubt是一个用于帮助前端工程师快速打包构建Vue等前端项目的npm包。它提供了一套自动化构建工具,使得项目的打包构建过程自动化,并且易于使用。 2. 安装 在终端中输入以下命令进行安装:...

    3 年前
  • npm 包 colorformatconverter 使用教程

    介绍 colorformatconverter 是一个用于在不同的颜色格式间进行转换的 npm 包。它支持多种常见的颜色格式,如 RGB、HEX、HSL、HSV 等,并能够直接转换它们之间的值。

    3 年前
  • npm 包 kvpbase 使用教程

    前言 在 Web 开发中,经常需要使用到后端存储的数据。kvpbase 是一款基于 Node.js 的键值对数据库,可以提供快速、可靠的数据存储服务。为了方便前端开发者使用 kvpbase,在 npm...

    3 年前
  • npm 包 olor-thief 使用教程

    随着 Web 技术的发展,我们对于前端领域的需求变得越来越多。其中一个非常重要的需求就是能够从一张图片中抽取出其主要颜色,从而为页面配色提供参考。在这个需求的背景下,olor-thief 这个 npm...

    3 年前
  • npm 包 diyimg-vue 使用教程

    前言 现在的网站几乎离不开图片展示,图片可以为网站增色,也能增加信息量,而随着 Web 技术的不断发展,前端工程师们很少再用去开发图片相关的功能,这时候我们可以选择利用一些现成的 npm 包来帮助我们...

    3 年前
  • npm 包 jsonqueryjs 使用教程

    简介 jsonqueryjs 是一个能够根据 JSON 数据查询、过滤、切割的 JavaScript 库。它提供了类似于 SQL 语言的接口,让开发者可以方便地从 JSON 数据中取得需要的数据。

    3 年前
  • npm 包 yatta 使用教程

    在前端开发中,我们常常需要使用一些工具或者库来辅助我们完成某些功能或者简化我们的开发流程,这时候我们就需要用到 npm 包。在本篇文章中,我们将会介绍一个非常实用的 npm 包 yatta,它可以帮助...

    3 年前

相关推荐

    暂无文章