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 相关文章推荐
jQuery中创建实例与原型继承揭秘
Dec 21 Javascript
jQuery Ajax异步处理Json数据详解
Nov 05 Javascript
js unicode 编码解析关于数据转换为中文的两种方法
Apr 21 Javascript
javascript 闭包详解
Jul 02 Javascript
AngularJs表单校验功能实例代码
Feb 09 Javascript
ajax请求data遇到的问题分析
Jan 18 Javascript
vue-cli 打包后提交到线上出现 "Uncaught SyntaxError:Unexpected token" 报错
Nov 06 Javascript
30分钟快速实现小程序语音识别功能
Nov 27 Javascript
JS实现判断数组是否包含某个元素示例
May 24 Javascript
微信小程序点击列表跳转到对应详情页过程解析
Sep 26 Javascript
Vue数据双向绑定原理实例解析
May 15 Javascript
keep-Alive搭配vue-router实现缓存页面效果的示例代码
Jun 24 Javascript
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
点评山进PR-D3L三波段收音机
2021/03/02 无线电
php设置编码格式的方法
2013/03/05 PHP
ubuntu下编译安装xcache for php5.3 的具体操作步骤
2013/06/18 PHP
PHP上传图片时判断上传文件是否为可用图片的方法
2016/10/20 PHP
IE6/7/8中Option元素未设value时Select将获取空字符串
2011/04/07 Javascript
Javascript中自动切换焦点实现代码
2012/12/15 Javascript
jquery选择器需要注意的问题
2014/11/26 Javascript
学习javascript文件加载优化
2016/02/19 Javascript
基于Bootstrap重置输入框内容按钮插件
2016/05/12 Javascript
AngularJS实践之使用NgModelController进行数据绑定
2016/10/08 Javascript
Bootstrap列表组学习使用
2017/02/09 Javascript
微信小程序实战之自定义toast(6)
2017/04/18 Javascript
jQuery用户头像裁剪插件cropbox.js使用详解
2017/06/07 jQuery
nuxt+axios解决前后端分离SSR的示例代码
2017/10/24 Javascript
微信小程序之裁剪图片成圆形的实现代码
2018/10/11 Javascript
微信小程序实现下拉菜单切换效果
2020/03/30 Javascript
微信小程序全局变量的设置、使用、修改过程解析
2019/09/24 Javascript
JavaScript的变量声明与声明提前用法实例分析
2019/11/26 Javascript
Vue 组件复用多次自定义参数操作
2020/07/27 Javascript
浅析python中的分片与截断序列
2016/08/09 Python
Python实现Windows和Linux之间互相传输文件(文件夹)的方法
2017/05/08 Python
python 使用值来排序一个字典的方法
2018/11/16 Python
python3对接mysql数据库实例详解
2019/04/30 Python
对Python3中列表乘以某一个数的示例详解
2019/07/20 Python
Tensorflow卷积实现原理+手写python代码实现卷积教程
2020/05/22 Python
如何理解Python中包的引入
2020/05/29 Python
python高级特性简介
2020/08/13 Python
THE OUTNET美国官网:国际设计师品牌折扣网站
2017/03/07 全球购物
Born鞋子官网:Born Shoes
2017/04/06 全球购物
SQL里面如何插入自动增长序列号字段
2012/03/29 面试题
仓库主管岗位职责
2014/03/02 职场文书
行政部经理助理岗位职责
2014/06/15 职场文书
冰峪沟导游词
2015/02/09 职场文书
中英文求职信范文
2015/03/19 职场文书
行政撤诉申请书
2015/05/18 职场文书
怎么禁用Win11输入法 最新Win11输入法关闭教程
2022/08/05 数码科技