npm 包 xes-ngrx-undo 使用教程

前言

在开发前端单页应用时,经常会遇到需要撤销操作和重做操作的需求。很多前端框架已经提供了类似的功能(如 Vue.js 的 Vuex),但是对于使用 Angular 的开发者来说,xws-ngrx-undo 是一个非常不错的选择。本文将介绍如何使用 xws-ngrx-undo 包来实现 Angular 应用的撤销/重做功能。

安装 xws-ngrx-undo

首先,我们需要安装 xws-ngrx-undo 包。可以使用以下命令来安装:

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

在应用中使用 xws-ngrx-undo

添加 xws-ngrx-undo 到依赖列表

打开 Angular 应用的 package.json 文件,找到 dependencies 节点,添加 xws-ngrx-undo 到依赖列表:

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

然后在终端中运行 npm install 命令来安装包。

添加到 @NgModule 的 providers 列表

打开目标组件所在的模块(通常是 app.module.ts),添加以下代码到 providers 列表中:

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

-- ---

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

这样就完成了 xws-ngrx-undo 的配置。

配置 Action

在每个需要进行撤销/重做操作的 Action 中添加以下代码:

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

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

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

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

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

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

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

在 Action 中,通过 ngrxUndongrxRedo 方法来分别向 Undo/Redo List 中添加快照;在调用时,只需要在原先的操作后添加 ngrxUndo(store),即可实现自动添加快照的功能。redo 方法用于执行逆向的操作。

在组件中使用撤销/重做

现在,我们已经可以在应用中添加快照,并且可以使用 ngrxUndongrxRedo 来将应用的状态恢复到之前的某个状态。下面我们来看如何在组件中使用撤销/重做功能。

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

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

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

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

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

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

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

组件中的 updateUndoRedo 方法用于根据当前的状态更新撤销和重做按钮的状态(是否可用)。onUndoonRedo 方法分别用于执行撤销和重做操作。onClear 方法用于清除所有的快照。

结语

上文简单介绍了如何使用 xws-ngrx-undo 来实现撤销/重做的功能。实际上,xws-ngrx-undo 还提供了很多高级的功能,比如可以通过 actions$ 流来自定义操作快照的生成,也可以通过 bufferSize 来设置快照的数量限制等等。我们希望这篇文章可以对你理解 xws-ngrx-undo 有所帮助,让你的 Angular 应用变得更加强大。

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


猜你喜欢

  • npm 包 swagger-pdf-compiler 使用教程

    前言 随着 Web、Mobile 全栈的快速发展,前端工程化已经成为了当今 Web 开发领域中一个非常重要的技术环节,其中使用 npm 包管理工具是不可避免的技术选择之一。

    3 年前
  • npm 包 named.css-webpack 使用教程

    前言 在前端开发中,样式的设计与管理是一个非常重要的部分。为了提高开发效率,我们可以利用一些工具来简化样式的管理。而 named.css-webpack 就是一个非常实用的样式管理工具。

    3 年前
  • npm包 ngx-phone-select 使用教程

    简介 ngx-phone-select是一个基于Angular框架的npm包,用于实现国际化的电话号码选择器。ngx-phone-select提供了一个易于使用和高度可定制的电话号码选择器组件,可以帮...

    3 年前
  • npm包@gitsupport/angular-tree-component使用教程

    前言 随着前端技术不断发展,树形组件也越来越普遍。其中,@gitsupport/angular-tree-component是一个十分优秀的树形组件,在本文中,我们将会介绍使用这个npm包的具体方法,...

    3 年前
  • npm 包 adm-zip-with-enc 使用教程

    前言 在前端开发中,经常需要对文件进行压缩和解压缩操作,而 Node.js 中的 adm-zip 是一款常用的处理 ZIP 文件的 npm 包。不过,adm-zip 并没有加密的功能,不适用于一些需要...

    3 年前
  • npm 包 generator-jopinari 使用教程

    对于前端开发者而言,提高工作效率是非常重要的。这里介绍一款 npm 包,它可以帮助我们自动生成前端项目模板,从而减少我们的开发工作量。这款包就是 generator-jopinari。

    3 年前
  • npm 包 myo-ts 使用教程

    简介 myo-ts 是一个基于 typescript 构建的前端开发库。它提供了丰富的工具和组件,为前端开发者提供了快速开发应用程序的解决方案。本文将阐述 myo-ts 的安装和基本使用方法,并提供一...

    3 年前
  • npm 包 raiblocks-client 使用教程

    raiblocks-client 是用于操作 RaiBlocks(XRB)加密货币的 JavaScript 类库。该类库提供了一个与 RaiBlocks 节点通信的接口,以便从 JavaScript ...

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

    简介 在前端开发中,使用 vue-range-input 可以方便地添加范围滑动条,它是一个基于 Vue.js 的范围滑动条组件。本文将详细介绍如何使用 npm 包 vue-range-input。

    3 年前
  • npm 包 filestojson 使用教程

    前言 在前端开发中,经常需要读取本地文件并将其转换成 JSON 格式,以便于前端程序在后端存储数据或者测试数据统一管理等。在这种情况下,我们通常需要借助一些工具或者写一些自己的代码来进行转换。

    3 年前
  • npm 包 one-src 使用教程

    一、什么是 one-src one-src 是一款基于 TypeScript 语言编写的 npm 包,用于方便地进行前端开发过程中的资源加载和管理。 相较于传统的资源加载方式,one-src 的主要优...

    3 年前
  • npm 包 angular-library-name-taiton-taiton 使用教程

    前言 在前端开发的过程中,我们经常会使用到各种各样的工具和框架。其中,npm 包是前端开发中常用的一种工具。npm 是 Node.js 的包管理器,可以方便地安装、升级、卸载前端库和框架。

    3 年前
  • NPM 包 lib.sass 使用教程

    在前端开发中,CSS 的编写和维护是一个非常重要的工作。传统的 CSS 编写方式通常是手工编写,但随着 CSS 代码量的增加,手工编写 CSS 变得越来越麻烦。因此,为了提高 CSS 的编写效率和可维...

    3 年前
  • npm 包 angular-transfer-http-response 使用教程

    在现代 web 应用程序中,数据的传输和加载是至关重要的。由于使用 HTTP 协议传输数据,因此 JavaScript 开发人员使用 Angular 所提供的 HttpClient 服务来加载和接收数...

    3 年前
  • npm 包 stylelint-de-standard 使用教程

    在前端开发中,很多人都会使用 stylelint 来检查 CSS 代码中的语法错误和最佳实践问题。而 stylelint-de-standard 是一个基于 Stylelint 的 npm 包,它提供...

    3 年前
  • npm包aws-serverless-express-edge使用教程

    AWS Serverless Express Edge 是一个npm包,可以将AWS Lambda函数与CloudFront CDN相结合,可以实现高效的边缘缓存和动态路由,适用于构建需要高性能和低延...

    3 年前
  • npm 包 funf 使用教程

    npm 是一个主流的 Node.js 包管理器,你可以在其中获取数万个 JavaScript 包,涉及前后端各种领域和技术。funf 是一个 npm 包,可以帮助你开发优雅、简洁的函数式代码。

    3 年前
  • npm 包 gemstone-theme 使用教程

    前言 在网页设计中,主题的选取非常重要,可以决定网站的整体风格和用户体验。随着前端技术的日益发展,很多开源社区都提供了各种主题样式,npm 就是一个很好的例子。本文将介绍一款名为 gemstone-t...

    3 年前
  • npm 包 react-awesome-social 使用教程

    简介 react-awesome-social 是一款方便快捷的 React 组件库,用于创建社交媒体场景中常用的 UI 元素。该组件库提供了许多常见的社交媒体平台的图标,可以直接用于构建社交媒体应用...

    3 年前
  • npm包 react-keyboard-time-input使用教程

    如果你正在开发一个与时间相关的 Web 应用程序,那么你可能需要一个时间输入框。然而,浏览器原生的时间输入框在不同的浏览器上有不同的样式和表现,并且不利于自定义样式。

    3 年前

相关推荐

    暂无文章