npm 包 redux-normalizr3-middleware 使用教程

简介

redux-normalizr3-middleware 是一个 Redux 中间件,它的主要作用是将 Action 中的数据进行归一化,使数据变得更有组织性和可读性。在实际应用中,这个中间件在处理数据过程中可以提高代码的可维护性,降低代码的冗余度。本文将对 redux-normalizr3-middleware 的使用进行详细讲解。

安装

redux-normalizr3-middleware 可以通过 npm 进行安装,在项目目录下执行以下命令:

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

安装完成后,我们需要在中间件链中引入它:

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

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

使用

redux-normalizr3-middleware 是一个中间件,我们需要了解如何使用 normalizr 这个工具。

normalizr 是什么

normalizr 可以将任意的复杂嵌套级别的 JSON 数据转换成一个扁平化的结构,也就是说它会将嵌套的对象打扁成一个个独立的实体。它提供了一组强大的规则来对 JSON 数据进行解析和转换。可以访问 normalizr 来查看其文档。

定义 normalizr 的 Schema

在使用 normalizr 时,我们需要定义一个 Schema 来描述需要被转换的数据。Schema 定义包含以下几个部分:

  • key (String): 代表当前 Schema 对象在要被规范化的数据中的字段名。
  • idAttribute (String): 可选值,代表当前 Schema 对象中的哪个字段作为该对象的唯一 ID,为字符串。
  • hasOne (Object 或 Array): 可选值,一个对象或者对象数组,用于描述和当前 Schema 相互关联的其他 Schema 类型,即表明当前 Schema 对象拥有一个或多个关联的 Schema,并存在于关联 Schema 中。
  • hasMany(Object 或 Array): 可选值,一个对象或者对象数组,用于描述和当前 Schema 相互关联的其他 Schema 类型,即表明当前 Schema 对象拥有多个关联的 Schema,并存在于关联 Schema 中。

定义完一个 Schema 后,我们可以通过传入 Schemanormalize 函数中,将 JSON 数据转化为规范化后的数据。

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

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

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

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

在 Redux 中使用

通过上述的内容,我们可以得到以下 Redux Action

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

为了让数据更具可读性和可维护性,我们需要将这些数据进行规范化,这就需要借助于 normalizrredux-normalizr3-middleware 的帮助。

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

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

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

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

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

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

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

完成上述的代码之后,我们就可以在组件中通过 Reduxconnect 函数将数据建立连接,然后通过以下方式获取分类后的数据:

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

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

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

至此 redux-normalizr3-middleware 的使用流程已经介绍完毕,希望对大家有所帮助。

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


猜你喜欢

  • npm 包 @oreofeolurin/serialize 使用教程

    在前端开发中,我们经常需要将数据转换为字符串或者将字符串转换为数据对象。@oreofeolurin/serialize 是一个非常方便的 npm 包,可以帮助我们轻松地实现这些转换操作。

    2 年前
  • npm 包 agglo 使用教程

    前言 Agglo 是一个基于 Gulp 的自动化构建工具,专门用于前端项目的打包、编译和压缩等操作,是一个非常优秀的工具。本文将介绍如何使用 Agglo 进行前端项目的构建并详细阐述其使用方法和意义。

    2 年前
  • npm 包 is-safe-path 使用教程

    在前端开发过程中,我们常常需要处理文件路径。但是,如果不小心给恶意用户提供了不安全的路径,就可能被攻击者利用来访问敏感数据或操作文件系统。is-safe-path 是一个能够判断文件路径是否安全的 n...

    2 年前
  • npm 包 recaf-datepicker 使用教程

    随着前端技术的不断发展,我们能够开发出越来越优秀的界面,同时也需要使用很多前端类的 npm 包,因为这些包可以极大地提高我们的工作效率。recaf-datepicker 就是一个非常优秀的 npm 包...

    2 年前
  • npm 包 n-paths-js 使用教程

    npm 包 n-paths-js 使用教程 n-paths-js 是一个轻量级的 npm 包,它可以轻松地生成任何形状和大小的 SVG 路径。在此文章中,我们将详细介绍如何使用 n-paths-js ...

    2 年前
  • 使用 multi-tool-cli 进行前端项目快速开发

    在前端项目开发中,经常需要进行一些重复性的操作,为了提高开发效率,工具类库就应运而生。其中,multi-tool-cli 是一个非常实用的 npm 包,它提供了许多基础的命令行工具,可以帮助我们快速生...

    2 年前
  • npm 包 broose_react-native-experiments 使用教程

    介绍 npm包是node.js平台上常用的包管理工具,通过npm可以便捷地查找与安装开源的JavaScript包,broose_react-native-experiments是一个基于react-n...

    2 年前
  • npm 包 gulp-jade-filter 使用教程

    在前端开发中,构建工具是必不可少的。其中,Gulp 是一个常用的前端构建工具之一,它可以自动化执行像压缩 JavaScript、CSS 或 HTML 文件、图像优化等一系列任务。

    2 年前
  • npm 包 hrtf-wavs-to-js-converters 使用教程

    前言 在 Web 开发中,音频处理一直是一个比较重要的领域。由于实现方式和环境限制,前端开发者在进行 Web 音频处理时经常会遇到一些问题。而使用 hrtf-wavs-to-js-converters...

    2 年前
  • npm 包 ng-crud-table 使用教程

    引言 ng-crud-table 是一个非常好用的 AngularJS 表格插件,可以快速创建表格,并支持增删改查操作。这篇文章将介绍如何使用 ng-crud-table 进行开发,并提供详细的教程、...

    2 年前
  • npm 包 npm-cicd 使用教程

    在前端开发中,npm 包管理器扮演重要角色。通过 npm 包,前端开发者可以便捷地引入第三方库、工具包以及自己编写的模块,从而提高开发效率,并且在维护更新时也变得十分方便。

    2 年前
  • npm 包 right-click-menu 使用教程

    前言 在 Web 开发中,右键菜单是一个非常常见的功能,可以提高用户的操作体验。但是,如何实现一个简单而美观的右键菜单呢?这里推荐一个 npm 包,即 right-click-menu。

    2 年前
  • npm 包 react-stas 使用教程

    react-stas 是一个基于 React 的可视化数据分析工具。它可以帮助开发者更加方便地收集和分析前端数据,提高网站或应用的性能。 本文将详细介绍 react-stas 的使用,包括安装、配置和...

    2 年前
  • npm 包 stas-core 使用教程

    在前端开发中,经常会用到各种 npm 包,其中 stas-core 是一款用于前端统计的数据框架。该包可以帮助开发人员更方便地收集和分析网站的访问数据,以便更好地了解用户行为和优化用户体验。

    2 年前
  • npm 包 stas-other-immutable 使用教程

    前言 随着前端开发的发展,JavaScript 技术也越来越成熟。为了提高开发效率和代码质量,许多开源的 npm 包相继出现,其中 stas-other-immutable 也是其中之一。

    2 年前
  • npm 包 context-block 使用教程

    前言 当我们进行前端开发时,常常需要在不同的组件和界面间传递数据和状态。不同的页面和组件通常具有不同的上下文环境,使用传统的方式很难在不同的上下文环境中正确地传递数据和状态。

    2 年前
  • npm 包 @sabbatical/mongoose-adaptor 使用教程

    前言 在开发过程中,Mongoose 是 Node.js 与 MongoDB 交互的一种非常流行和方便的工具,但是,对于一些新手来说,开始使用 Mongoose 可能会有一些难度。

    2 年前
  • npm 包 file-tree-list 使用教程

    前言 在前端开发中,我们经常需要处理文件和文件夹,而在很多场景下,我们需要将文件和文件夹的目录结构以树形的形式呈现出来。如果手动编写这样的树形结构代码,不仅复杂,而且容易出错,因此我们可以使用 npm...

    2 年前
  • npm 包 eslint-config-qb 使用教程

    在前端开发中,我们都知道代码规范对于代码质量和可维护性的重要性,而 Eslint 是一个非常流行的工具用于强制实施一致的代码风格。但是,在实际的开发过程中,我们可能需要一个定制化的 Eslint 配置...

    2 年前
  • npm 包 vd-modal 使用教程

    vd-modal 是一个基于 Vue.js 的模态窗口组件,可以帮助前端开发者快速创建和使用模态窗口。本文将介绍如何安装和使用 vd-modal。 安装 vd-modal 安装 vd-modal 可以...

    2 年前

相关推荐

    暂无文章