npm 包 redux-action-processor 使用教程

前言

Redux 是一种可预测的状态管理容器,而 Redux Action 是为了描述数据的变化而发送给 Redux Store 的普通 JavaScript 对象。

Redux Action Processor (RAP) 则是一个处理 Redux Action 的工具,并且可以实现更高级的功能,例如异步调用,条件执行等。在本文中,我们将介绍 npm 包 redux-action-processor 的使用教程。

安装

你可以使用 npm 安装 redux-action-processor

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

同时,你需要将 redux-action-processor 创建的 Redux Store 和 Middleware 引入到你的应用程序中。

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

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

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

基本使用

RAP 可以处理两种类型的 Redux Action: Plain Object 和 Function。

对于 Plain Object,RAP 可以触发 beforeafter 两个事件来处理,并可以通过设置 stopPropagation 属性来阻止执行后续 Middleware。

对于 Function,RAP 会调用此函数,并传入 dispatch 和 getState 两个参数,同时支持 Promise 异步调用。

在 Action 完成后,RAP 会调用 Redux Store 的 dispatch 方法来 dispatch 一个 Action。

下面是一个在 RAP 中使用 Plain Object 和 Function 的示例:

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

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

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

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

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

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

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

高级使用

除了基本功能之外,RAP 还支持一些高级功能,例如条件执行,中止流程等。可以通过配置 rules 属性来实现这些功能。

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

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

上述代码中,我们设置了两个 rules。

第一个 rule 的 pattern 为 FETCH_DATA,condition 验证 payload 是否大于 10,如果满足条件,则 effect 返回一个 ADD_ALERT 的 Action。

第二个 rule 的 pattern 为以 FILTER_ 开头的任意字符串,condition 验证 Redux Store 的 filter 属性是否等于 payload,如果等于,则 effect 返回一个 TOGGLE_FILTER 的 Action。

结语

Redux Action Processor 是一个用于处理 Redux Action 的非常有用的工具,它不仅提供了基本功能,还支持高级功能,例如条件执行和中止流程等。

通过本文,你已经可以更好的了解和使用 redux-action-processor 这个 npm 包了。如果你有任何问题或建议,请随时在评论区留言。

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


猜你喜欢

  • npm 包 roboto-stylus 使用教程

    介绍 Roboto-stylus 是一个 npm 包,提供了 Google 出品的 Roboto 字体的 stylus 实现。将其引入项目后,可以在 stylus 文件中直接使用 Roboto 字体的...

    3 年前
  • npm 包 callbag-timestamp 使用教程

    在前端开发中,我们常常需要对流式数据进行处理。而在 JavaScript 中,我们可以使用 callbags 来处理这些数据流。其中,callbag-timestamp 是一种常用的 npm 包,用于...

    3 年前
  • npm 包 pouch.cors 使用教程

    前言 在 Web 前端开发中,经常会使用到浏览器端存储数据的功能,这时候就需要用到一些数据存储解决方案。其中,PouchDB 是一个非常不错的浏览器端数据库,它可以让你在浏览器中以本地方式存储数据。

    3 年前
  • npm 包 web-watermark 使用教程

    在前端开发中,我们经常需要添加水印来保护网站的版权以及数据的安全性。而 npm 包 web-watermark 是一个十分方便的工具,可以帮助我们快速添加水印。本篇文章将详细介绍 npm 包 web-...

    3 年前
  • npm 包 @kimmel/array-shuffle 使用教程

    在前端开发过程中,我们常常需要对数组进行随机排序。而 npm 包 @kimmel/array-shuffle 就可以帮助我们轻松地实现这一功能。 安装 首先,我们需要在命令行工具中使用 npm 安装该...

    3 年前
  • npm 包 hyperdb-storage 使用教程

    在前端开发中,数据存储是一个十分重要的环节。npm 包 hyperdb-storage 是一个优秀的轻量级 JavaScript 库,它可以用来存储和管理你的应用数据,为你的开发提供了很大的便利。

    3 年前
  • npm 包 long-api-task-requester 使用教程

    在前端开发中,我们往往需要向服务器发送异步请求去获取数据,但是一些复杂的业务场景,如批处理、分布式计算等,可能需要在服务器上执行一些耗时较长的任务,同时客户端又需要不断地查询任务进度和结果。

    3 年前
  • npm包rn-touchable-sort-list使用教程

    #npm包rn-touchable-sort-list使用教程 介绍 rn-touchable-sort-list是一款基于React Native开发的组件,它可以方便地将列表中的项进行拖拽排序。

    3 年前
  • npm 包 svgpdf 使用教程

    SVG 是可伸缩矢量图形 (Scalable Vector Graphics) 的简称,它是一种基于 XML 语法的向量图形格式,可用于在网页中显示。同时,PDF 是一种非常流行的文件格式,可用于文档...

    3 年前
  • npm 包 grimm-user-pic 使用教程

    前言 在我们的日常前端开发中,使用到的 npm 包已经不可胜数了。随着前端技术的不断发展,我们也需要不断学习新的知识和掌握新的工具。今天,我们来介绍一款非常实用的 npm 包:grimm-user-p...

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

    介绍 npm 包 jonas-palindrome 是一个用于检测回文字符串的 JavaScript 库。它可以判断给定字符串是否回文,并针对不同需求提供不同类型的返回结果。

    3 年前
  • npm包lemme-lex的使用教程

    前言 在前端开发中,有许多需要进行语法解析的工作,比如编译器、解释器等。而为了更方便地进行语法解析,我们可以使用一些现成的npm包。其中,lemme-lex就是一款非常实用的npm包。

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

    1. 简介 react-native-c8osdk 是一个基于 React Native 平台的 C8OSDK 开发工具包,可以帮助开发者快速搭建对接 C8OSDK 的移动应用,提供了丰富的 API ...

    3 年前
  • npm 包 adt-maybe 使用教程

    在前端开发中,我们常常需要处理一些变量的值是否存在,以及如何对不存在的值进行处理。这就需要我们对变量进行 null 和 undefined 的判断。但这种判断的代码太过繁琐,容易出错,而且难以维护。

    3 年前
  • npm 包 aibcore-mnemonic 使用教程

    简介 aibcore-mnemonic 是一个基于 BIP39 标准的 JavaScript 库,用于生成和存储助记词,并从助记词中恢复秘钥和地址。它可以帮助您轻松地管理多个加密货币钱包。

    3 年前
  • npm 包 donejs-travis-encrypt 使用教程

    在前端开发中,自动化构建流程的重要性越来越被重视。与此同时,Travis CI 是一个广受欢迎的 CI 工具,它可以帮助我们实现自动化构建、测试和部署。但是,当我们涉及到使用 Travis CI 时,...

    3 年前
  • npm 包 signalr-jquery-shim 使用教程

    随着 JavaScript 技术的不断发展,前端开发的范围也愈加广泛。而在这个领域中,npm 包成为非常重要的工具之一。signalr-jquery-shim 是一个 npm 包,用于扩展 Signa...

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

    在前端开发中,网络请求是必须的一个环节,而 npm包 x-http-lib 是一款实用的网络请求类库,它可以在不同的前端项目中方便快捷地完成网络请求。本文将为您详细介绍如何使用 x-http-lib ...

    3 年前
  • npm包`@vagrantir/rc-device-targeting`使用教程

    前言 在当前互联网时代,移动互联网已经成为人们日常生活中必不可少的一部分,有了移动设备,我们可以随时随地的访问互联网,使用各种应用。但是,移动设备的形式和种类千变万化,这给前端开发带来了很大的挑战,因...

    3 年前
  • npm 包 @stormgle/react-user 使用教程

    @stormgle/react-user 是一个基于 React 的用户管理组件库。它提供了一些方便的 React 组件,让你可以轻松地在你的 React 应用中管理用户。

    3 年前

相关推荐

    暂无文章