javascript设计模式 ? 备忘录模式原理与用法实例分析


Posted in Javascript onApril 21, 2020

本文实例讲述了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.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
JavaScript获得选中文本内容的方法
Dec 02 Javascript
javascript 可以拖动的DIV(二)
Jun 26 Javascript
把input初始值不写value的具体实现方法
Jul 04 Javascript
网页从弹窗页面单选框传值至父页面代码分享
Sep 29 Javascript
Angular.js中ng-include用法及多标签页面的实现方式详解
May 07 Javascript
JS实现简单短信验证码界面
Aug 07 Javascript
基于vue-cli配置lib-flexible + rem实现移动端自适应
Dec 26 Javascript
详解Vue项目编译后部署在非网站根目录的解决方案
Apr 26 Javascript
jQuery模拟12306城市选择框功能简单实现方法示例
Aug 13 jQuery
Vue 利用指令实现禁止反复发送请求的两种方法
Sep 15 Javascript
基于vue中的scoped坑点解说
Sep 04 Javascript
vue-cli3.0修改打包后的文件名和文件地址,打包后本地运行报错解决
Apr 06 Vue.js
VUE+elementui组件在table-cell单元格中绘制微型echarts图
Apr 20 #Javascript
Vue的全局过滤器和私有过滤器的实现
Apr 20 #Javascript
深入浅析JavaScript中的in关键字和for-in循环
Apr 20 #Javascript
vue实现购物车功能(商品分类)
Apr 20 #Javascript
vue实现淘宝购物车功能
Apr 20 #Javascript
javascript利用键盘控制小方块的移动
Apr 20 #Javascript
vue实现购物车的监听
Apr 20 #Javascript
You might like
phpMyAdmin出现无法载入 mcrypt 扩展,请检查PHP配置的解决方法
2012/03/26 PHP
php代码中使用换行及(\n或\r\n和br)的应用
2013/02/02 PHP
php的webservice的wsdl的XML无法显示问题的解决方法
2014/03/11 PHP
Zend Framework教程之Application用法实例详解
2016/03/14 PHP
Add a Formatted Table to a Word Document
2007/06/15 Javascript
解决js数据包含加号+通过ajax传到后台时出现连接错误
2013/08/01 Javascript
js左侧三级菜单导航实例代码
2013/09/13 Javascript
js鼠标悬浮出现遮罩层的方法
2015/01/28 Javascript
JavaScript之数组(Array)详解
2015/04/01 Javascript
jQuery实现仿百度帖吧头部固定导航效果
2015/08/07 Javascript
Three.js学习之Lamber材质和Phong材质
2016/08/04 Javascript
javascript数组常用方法汇总
2016/09/10 Javascript
ES6概念 ymbol.for()方法
2016/12/25 Javascript
JS array数组检测方式解析
2020/05/19 Javascript
微信小程序组件生命周期的踩坑记录
2021/03/03 Javascript
Python 文件读写操作实例详解
2014/03/12 Python
Python基于回溯法子集树模板解决m着色问题示例
2017/09/07 Python
python 3.0 模拟用户登录功能并实现三次错误锁定
2017/11/01 Python
Python实现爬取百度贴吧帖子所有楼层图片的爬虫示例
2018/04/26 Python
python自动发送测试报告邮件功能的实现
2019/01/22 Python
手把手教你使用Python创建微信机器人
2019/04/29 Python
在django中图片上传的格式校验及大小方法
2019/07/28 Python
Jupyter notebook设置背景主题,字体大小及自动补全代码的操作
2020/04/13 Python
python + selenium 刷B站播放量的实例代码
2020/06/12 Python
vscode调试django项目的方法
2020/08/06 Python
Ref与out有什么不同
2012/11/24 面试题
史上最全面的Java面试题汇总!
2015/02/03 面试题
《桂林山水》教学反思
2014/02/08 职场文书
企业宣传工作方案
2014/06/02 职场文书
创建绿色社区汇报材料
2014/08/22 职场文书
2014最新预备党员思想汇报范文:中国梦,我的梦
2014/10/25 职场文书
2014幼儿园卫生保健工作总结
2014/12/05 职场文书
运动会通讯稿100字
2015/07/20 职场文书
大学生饮品店创业计划书范文
2019/07/10 职场文书
使用CSS实现小三角边框原理解析
2021/11/07 HTML / CSS
利用nginx搭建RTMP视频点播、直播、HLS服务器
2022/05/25 Servers