javascript设计模式 – 备忘录模式原理与用法实例分析
本文实例讲述了javascript设计模式 – 备忘录模式原理与用法。分享给大家供大家参考,具体如下:
介绍:在我们的开发中偶尔会遇到这样一种情况,需要对用户的行为进行撤销。要想实现撤销,首先需要保存软件系统的历史状态,当用户执行撤销时用之前的状态覆盖当前状态。本节介绍的备忘录模式提供了一种状态恢复的实现机制,使得用户可以方便的回到一个特定的历史步骤。
定义:在不破坏封装的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态,这样可以在以后将对象恢复到原先保存的状态,它是一种对象行为模式,其别名为token。
场景:使用js实现一个简单的状态机,用于状态的保存,回退。实现下备忘录模式。
示例:
var memento = function(state){ var _state = state; this.getstate = function(){ return _state; } } var originator = function(){ var _state; this.setstate = function(state){ _state = state; } this.getstate = function(){ return _state; } this.savestatetomemento = function(){ return new memento(_state) } this.getstatefrommemento = function(memento){ _state = memento.getstate(); } } var caretaker = function(){ var _mementolist = []; this.add = function(memento){ _mementolist.push(memento); } this.get = function(index){ return _mementolist[index]; } } var originator = new originator(); var caretaker = new caretaker(); originator.setstate("state 1"); originator.setstate("state 2"); caretaker.add(originator.savestatetomemento()); originator.setstate("state 3"); caretaker.add(originator.savestatetomemento()); originator.setstate("state 4"); console.log("当前状态: " + originator.getstate()); // 当前状态: state 4 originator.getstatefrommemento(caretaker.get(0)); console.log("恢复第一次保存状态: " + originator.getstate()); // 恢复第一次保存状态: state 2 originator.getstatefrommemento(caretaker.get(1)); console.log("恢复第二次保存: " + originator.getstate()); // 恢复第二次保存: state 3
这个例子里面originator称为原发器,可以通过savestatetomemento创建一个备忘录,存储当前状态。memento是一个备忘录对象,只供原发器使用,提供状态提取方法。caretaker称之为负责人也可以叫管理者,它负责保存备忘录,但是不能对备忘录内容进行操作或检查
备忘录模式总结:
优点:
* 提供了一种状态恢复的时间机制,使得用户可以方便的回退到一个特定的历史步骤。
* 备忘录实现了对信息的封装,一个备忘录对象是一种原发器对象状态的表示,不会被其他代码所改动。
缺点:
* 备忘录模式的主要缺点是资源消耗过大,如果需要保存的原发器类的成员变量太多,就不可避免的需要占用大量的存储空间。
适用场景:
* 保存一个对象在某一时刻的全部或部分状态
感兴趣的朋友可以使用在线html/css/javascript代码运行工具:http://tools.jb51.net/code/htmljsrun测试上述代码运行效果。
上一篇: 宋江的军师