撤销和恢复功能,英文为:Undo和Redo,快捷键分别为Ctrl+Z和Ctrl+Y。它们是一组很常见的功能,在很多系统和软件中都有这两个功能。随着浏览器的功能越来越强,Web App将越来越占据重要位置,基于客户端JavaScript实现的撤销和恢复功能将越来越多,最近在工作中,完成了一个web系统的撤销和恢复功能,特写下一些心得以供分享。
首先介绍一下我们系统基本内容:我们系统是一套建站系统,通过不同模块的拖拽和设置便可以简单的制作网站。其中的设置操作是可以撤销恢复的,如果你不小心误操作,也可以很方便的返回未设置前的状态。而我开发的就是这个功能。下面我就介绍开发的一些内容吧。
1.不重新发明轮子,寻找合适的库帮忙
撤销和恢复功能是一个常用的功能,也是一个实现起来比较繁琐的功能。如果自己重头实现,要自己设计类结构,设计底层的栈数据结构,维护状态,很不方便也很容易出错。所以一般不同的客户端技术都有对应的封装。客户端JS也不例外,它就是undo.js,https://github.com/jzaefferer/undo
undo.js封装了一套比较通用的实现撤销和恢复功能架构,而它则帮你实现了内部的数据结构和状态的维护。使用undo.js主要有一下几步。
//初始化栈 var stack = new Undo.Stack(); //封装Command类 EditCommand = Undo.Command.extend({ constructor: function(textarea, oldValue, newVa