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 包 ql-base 使用教程

    ql-base 是一个实用的前端工具类包,其中包含了一些常用的方法和工具函数。本文将详细介绍如何使用 ql-base 包,包括安装、使用及示例代码,并进一步探讨其学习和指导意义。

    3 年前
  • npm 包 ql-sdk 使用教程

    介绍 ql-sdk 是一个基于 Node.js 的 npm 包,适用于前端开发,可以帮助开发者使用 QiNiu 的七牛云存储服务。 安装 使用 npm 命令进行安装: --- ------- ----...

    3 年前
  • npm 包 Zeu 使用教程

    如果你是一个前端开发人员,那么你可能会需要一些能够提高你效率的工具。其中一个非常流行的工具就是 NPM,它是一个用于 JavaScript 项目包管理的软件包管理器。

    3 年前
  • npm 包 @date-io/date-fns-old 使用教程

    作为前端开发人员,在项目开发中需要进行日期格式化的操作,而很多时候我们都会使用的 date-fns 库。但是,我们有时候需要使用的是较旧版本的 date-fns,这时候可以使用 npm 包 @date...

    3 年前
  • npm 包 depute 使用教程

    什么是 depute depute 是一个 JavaScript 库,用于将对象转换为代理对象,以允许在对象上进行劫持行为。通过使用 depute,开发者可以更改对象的行为,以便更好地控制应用程序的工...

    3 年前
  • npm 包 graphql-endpoint 使用教程

    在现代 Web 开发中,GraphQL 已成为了前后端交互中极其重要的一环。作为一种强类型的查询语言,它的使用极大地简化了前后端数据交互的繁琐。本文将介绍一个 npm 包 graphql-endpoi...

    3 年前
  • npm 包 kabanery-glare 使用教程

    简介 kabanery-glare 是一款基于 kabanery 引擎的 JavaScript 库,它提供了一些优秀的工具函数,用于处理 DOM 元素,并通过对这些函数的组合,来轻松的构建 Web 应...

    3 年前
  • npm 包 polix-rpc 使用教程

    简介 polix-rpc 是一个基于 JSON-RPC 协议的远程过程调用(RPC)库,可用于 JavaScript 程序的服务器端和客户端间通讯,也可以在 Web 浏览器中使用。

    3 年前
  • npm 包 string-to-ascii 使用教程

    前言 在前端开发过程中,有时我们需要将字符串转换成 ASCII 码,以便进行加密或其他处理。这时,可以利用 npm 上的 string-to-ascii 包来帮助我们快速完成。

    3 年前
  • npm 包 particion 使用教程

    什么是 particion? particion 是一个前端库,它提供了一种在页面上拖拽和分割视图的功能。 使用 particion,您可以轻松地创建分割页面和可拖拽的视图,将其应用于您的 Web 应...

    3 年前
  • npm 包 @endemolshinegroup/generator-codebuild 使用教程

    在前端开发中,使用自动化构建工具可以提高开发效率和协作性。本教程将详细介绍如何使用 @endemolshinegroup/generator-codebuild 这个 npm 包来生成自动化构建模板。

    3 年前
  • npm 包 ionic-cordova-plugins-wechat 使用教程

    近年来,微信手机应用已经成为人们使用最广泛的社交软件之一。对于开发人员而言,实现微信功能的需求也越来越多。借助 npm 包 ionic-cordova-plugins-wechat,开发人员能够更加方...

    3 年前
  • npm 包 make-geo-json 使用教程

    前言 在前端开发中,经常涉及到地理位置数据。为了更方便地处理和呈现这些数据,我们可以使用 npm 包 make-geo-json,它可以将经纬度数据转换为 GeoJSON 格式,并支持添加自定义属性,...

    3 年前
  • npm 包 phonetics.io 使用教程

    前言 phonetics.io 是一个 npm 包,它可以帮助前端开发者将文本转换为音标,进而实现语音合成等功能。在语音技术逐渐普及的今天,phonetics.io 成为了前端开发者必不可少的工具之一...

    3 年前
  • npm 包 tries.io 使用教程

    引言 在前端领域,我们经常需要对一些字符串进行拼音排序或者模糊匹配。对于中文等复杂语言而言,这是一项十分困难的任务。npm 包 tries.io 就是一个帮助我们完成这项任务的工具。

    3 年前
  • npm 包 apartment-ui 使用教程

    介绍 Apartment-ui 是一个前端组件库,提供了众多常用的 UI 组件供开发者使用,包括按钮、表单组件、表格、对话框、轮播等等,能够大大提高开发效率。 安装 在使用 apartment-ui ...

    3 年前
  • npm 包 form-making-iview 使用教程

    在前端开发中,表单是一个必不可少的组件。然而,表单的开发过程往往需要大量的重复性工作和样式调整,让开发效率和代码质量受到影响。因此,一些优秀的前端开发者为我们提供了一些非常棒的表单生成工具,其中之一就...

    3 年前
  • npm 包 utils-xk 使用教程

    介绍 在前端开发中,我们经常会遇到需要使用一些工具函数的场景,例如,日期格式化、URL 参数解析、字符串转换等。为了方便开发者使用这些常用的函数,我们可以使用已经封装好的 npm 包来进行开发。

    3 年前
  • npm包 vue2-aliplayer使用教程

    前言 如果你正在开发一个基于Vue.js的视频应用程序,你可能会遇到需要集成阿里云的视频播放器的问题。虽然阿里云提供了自己的JavaScript播放器,但是使用Vue.js来集成它们并不总是那么容易。

    3 年前
  • npm 包 cordova-plugin-jb-geolocation 使用教程

    前言 在前端开发中,使用定位技术是非常常见的需求之一。cordova-plugin-jb-geolocation 是一个基于 Cordova 平台的定位插件,它可以让开发者在项目中轻松获取设备的地理位...

    3 年前

相关推荐

    暂无文章