0

0

HTML如何撤销操作_JavaScript状态管理实现【方案】

蓮花仙者

蓮花仙者

发布时间:2025-12-30 19:45:09

|

617人浏览过

|

来源于php中文网

原创

可撤销操作可通过五种方案实现:一、命令模式用栈记录执行/撤销对象;二、状态快照+索引管理;三、proxy代理拦截变更;四、redux中间件增强;五、immer实现不可变状态与时间旅行。

html如何撤销操作_javascript状态管理实现【方案】

如果您在网页中执行了某个操作(例如表单提交、DOM 修改或状态变更),但希望回退到之前的状态,则需要通过 JavaScript 实现可撤销的操作机制。以下是几种可行的实现方案:

一、命令模式记录操作历史

该方案将每个可撤销操作封装为一个具有执行(execute)和撤销(undo)方法的对象,通过结构保存操作历史,便于按顺序回退。

1、定义命令基类,包含 execute 和 undo 两个空方法;

2、为每类操作创建具体命令类,例如 TextEditCommand 负责文本修改,其 execute 存储当前值并更新 DOM,undo 将 DOM 恢复为 previousValue;

立即学习Java免费学习笔记(深入)”;

3、维护一个 commands 数组作为操作栈,每次执行命令后调用 push 方法入栈;

4、触发撤销时,从 commands 数组末尾取出最近命令,调用其 undo 方法,并使用 pop 移除该命令;

5、可选实现重做功能:另设一个 redoStack 数组,在 undo 时将命令 push 进 redoStack,重做时从 redoStack pop 并 execute。

二、状态快照 + 索引管理

该方案定期或在关键操作节点对应用状态进行深拷贝并存入数组,通过维护当前索引 position 来控制前进与回退。

1、初始化一个 states 数组和 position 变量,初始值为 0;

2、每次发生可撤销操作前,调用 JSON.parse(JSON.stringify(state)) 或 structuredClone(若支持)生成当前状态快照,并 push 入 states;

3、同时将 position 设为 states.length - 1,确保指向最新状态;

4、执行撤销时,判断 position > 0,若成立则 position--,再将 states[position] 赋值给当前 state 并同步更新视图;

5、执行重做时,判断 position

三、使用 Proxy 动态拦截状态变更

该方案利用 Proxy 对状态对象进行包装,自动捕获所有赋值操作,并在每次变更前保存上一状态,形成隐式快照链。

1、创建一个 history 数组和 current 属性,初始时将初始状态存入 history 并设 current = 0;

动感购物HTML
动感购物HTML

修正了V1.10的一些BUG感购物HTML系统是集合目前网络所有购物系统为参考而开发,代码采用DIV编号,不管从速度还是安全我们都努力做到最好,此版虽为免费版但是功能齐全,无任何错误,特点有:专业的、全面的电子商务解决方案,使您可以轻松实现网上销售;自助式开放性的数据平台,为您提供充满个性化的设计空间;功能全面、操作简单的远程管理系统,让您在家中也可实现正常销售管理;严谨实用的全新商品数据库,便于

下载

2、用 Proxy 包裹原始状态对象,set 拦截器中先将当前状态深拷贝后 push 入 history,再更新 target;

3、每次 set 触发后,current 自增 1;

4、定义 undo 函数:若 current > 0,则 current--,并将 history[current] 浅复制或深复制回目标状态对象;

5、注意避免 Proxy 嵌套导致的性能问题,建议仅对顶层状态对象代理,子属性变更仍需手动触发 notify。

四、基于 Redux 架构的可撤销中间件

该方案扩展 Redux store,通过增强 dispatch 行为,在每次 action 分发前保存当前 state,并提供专用的 UNDO/REDO action 类型。

1、编写 middleware,监听所有非 UNDO/REDO 的 action,在 reducer 执行前将当前 getState() 结果 push 到本地 undoStack;

2、清空 redoStack(因新操作使重做失效);

3、定义 UNDO action 处理逻辑:若 undoStack.length > 1,pop 当前 state,将前一个 state 作为新 state 传入 replaceReducer 或 dispatch 替换;

4、定义 REDO action:若 redoStack 非空,pop 一个 state 并设为当前 state;

5、使用 combineReducers 时,确保撤销逻辑作用于根 state,而非单个 slice。

五、使用 Immer 实现不可变状态与时间旅行

该方案借助 Immer 的 produce 机制,在保持代码可读性的同时自动生成不可变状态快照,配合外部索引实现撤销导航。

1、引入 immer 库,声明一个 baseState 和一个 drafts 数组用于存放 produce 后的 draft 状态;

2、每次用户操作触发 produce 调用,将返回的新状态 push 入 drafts,并更新 currentIndex;

3、撤销函数中,若 currentIndex > 0,则 currentIndex--,然后将 drafts[currentIndex] 作为当前有效状态;

4、为避免内存膨胀,限制 drafts 最大长度(如最多保留 50 个快照),超出时 shift 删除最早项;

5、视图层通过监听 currentIndex 变化,使用 drafts[currentIndex] 渲染对应状态。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
什么是中间件
什么是中间件

中间件是一种软件组件,充当不兼容组件之间的桥梁,提供额外服务,例如集成异构系统、提供常用服务、提高应用程序性能,以及简化应用程序开发。想了解更多中间件的相关内容,可以阅读本专题下面的文章。

182

2024.05.11

Golang 中间件开发与微服务架构
Golang 中间件开发与微服务架构

本专题系统讲解 Golang 在微服务架构中的中间件开发,包括日志处理、限流与熔断、认证与授权、服务监控、API 网关设计等常见中间件功能的实现。通过实战项目,帮助开发者理解如何使用 Go 编写高效、可扩展的中间件组件,并在微服务环境中进行灵活部署与管理。

225

2025.12.18

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

453

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

331

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

435

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

601

2023.08.10

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

相关下载

更多

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.8万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号