JS设计模式14-备忘录模式

分页和撤销例子

作者 Trekerz 日期 2017-09-30
JS设计模式14-备忘录模式

备忘录模式的基础

定义:在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样就可以将该对象恢复到原先保存的状态。
作用:在我们的开发中偶尔会遇到这样一种情况,需要对用户的行为进行撤销。要想实现撤销,首先需要保存软件系统的历史状态,当用户执行撤销时用之前的状态覆盖当前状态。

本节介绍的备忘录模式提供了一种状态恢复的实现机制,使得用户可以方便的回到一个特定的历史步骤。备忘录模式在js中经常用于数据缓存。

使用场景:分页控件、撤销组件

分页控件

var Page = function(){
let page = 1,
cache = {},
data;
return function( page ){
if ( cache[ page ] ){
data = cache[ page ];
render( data );
}else{
Ajax.send( 'cgi.xx.com/xxx', function( data ){
cache[ page ] = data;
render( data );
});
}
}
}();

PS:分页控件, 从服务器获得某一页的数据后可以存入缓存。以后再翻回这一页的时候,可以直接使用缓存里的数据而无需再次请求服务器

撤销组件

// 备忘录构造函数
var Memento = function(state){
var _state = state;
this.getState = function(){
return _state;
}
}

// 原发器,saveStateToMemento创建一个备忘录,存储当前状态。
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();
}
}

// CareTaker称之为负责人也可以叫管理者,它负责保存备忘录
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

PS:这个例子里面Originator称为原发器,可以通过saveStateToMemento创建一个备忘录,存储当前状态。 Memento是一个备忘录对象,只供原发器使用,提供状态提取方法。CareTaker称之为负责人也可以叫管理者, 它负责保存备忘录,但是不能对备忘录内容进行操作或检查。

优点

  • 提供了一种状态恢复的时间机制,使得用户可以方便的回退到一个特定的历史步骤。
  • 备忘录实现了对信息的封装,一个备忘录对象是一种原发器对象状态的表示,不会被其他代码所改动

缺点

  • 备忘录模式的主要缺点是资源消耗过大,如果需要保存的原发器类的成员变量太多,就不可避免的需要占用大量的存储空间。

参考文档:
《javascript设计模式 – 备忘录模式》
【Javascript设计模式14】-备忘录模式


end -