JS设计模式之备忘录模式
2023-06-13 09:13:55 时间
源码
点击这里前往Github获取本文源码
意图
在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可将该对象恢复到原先保存的状态。 ——《设计模式:可复用面向对象软件的基础》中文版第212页
这个常常被运用于游戏存档、操作撤销等场景。
示例
这是一个悲催的故事,内容是一个人先涨薪然后通过本文提到的功能恢复了原来的薪水。如下:
class Staff {
constructor(name, salary) {
this.name = name
this.salary = salary
}
raiseSalary(salary) {
this.salary += salary
}
store() {
const memento = JSON.stringify(this)
return memento
}
restore(memento) {
Object.assign(this, JSON.parse(memento))
}
}
class StaffCareTaker {
mementos = {}
set(key, memento) {
this.mementos[key] = memento
}
get(key) {
return this.mementos[key]
}
}
const careTaker = new StaffCareTaker()
const staff = new Staff('Bob', 12500)
careTaker.set(1, staff.store())
staff.raiseSalary(5000)
console.log(staff.salary)
// 17500
staff.restore(careTaker.get(1))
console.log(staff.salary)
// 12500
Memento
指的是存储下来的数据,本文中它是一个JSON字符串。CareTaker
负责保存数据,它不能操作这些数据。Originator
,即本文的Staff
,是一个可以保存状态并恢复状态的对象。
基本的模型就是上面三个。
参考
相关文章
- Fabric.js 使用纯色遮挡画布(前景色)
- js异步编程的三种模式
- JS设计模式之装饰器模式
- JS设计模式之职责链模式
- JS设置定时器_js设置定时器
- js异步编程的三种模式_2023-03-02
- JS知识点梳理--作用域、作用域链、柯里化、闭包
- JS实现全屏模式
- 【JS 逆向百例】猿人学系列 web 比赛第五题:js 混淆 - 乱码增强,详细剖析
- js-灵活可拆分的职责链模式
- resumable.js —— 基于 HTML 5 File API 的文件上传组件 支持续传后台c#实现详解编程语言
- JS在Oracle中的应用(js如何oracle)
- 一些不错的js函数ajax
- Jquery与JS两种方法仿twitter/新浪微博高度自适应无缝滚动实现代码
- js数据类型转换总结笔记
- js延迟加载改变JS的位置加快网页加载速度
- JS调用CS里的带参方法实例
- js点击页面其他地方关闭弹出层(示例代码)
- JS控制图片等比例缩放的示例代码
- js获取当前地址JS获取当前URL的示例代码
- 浅谈JS闭包中的循环绑定处理程序
- Node.js中使用事件发射器模式实现事件绑定详解