一、装饰器模式
介绍
- 顺序访问一个集合
- 使用者无需知道集合的内部结构(封装)
data:image/s3,"s3://crabby-images/70d2b/70d2b39643b2aed7e03ac8c36dae9e4197aa8e72" alt=""
data:image/s3,"s3://crabby-images/7276a/7276add9f4c7865437bfb55715ea87fff60746a2" alt=""
data:image/s3,"s3://crabby-images/7e9bd/7e9bd2e6ca2d253387b1c297cc05f6cc39d6c5a7" alt=""
data:image/s3,"s3://crabby-images/116ce/116ce8d0419117a2c46e09fb8232e5d92e24965b" alt=""
二、状态模式
介绍
- 一个对象又状态变化(如收藏/取消收藏)
- 每次状态变化都会触发一个逻辑
- 不能总是用If...else来控制,尤其在比较的多的情况下
data:image/s3,"s3://crabby-images/ebf40/ebf40d7179f2882126cd1b935cdb7e15fec92a18" alt=""
一个切换红黄绿灯的例子
data:image/s3,"s3://crabby-images/30673/306732f725d4c33ac346146c8054e4e07055437e" alt=""
data:image/s3,"s3://crabby-images/b2f2c/b2f2ce9a24d94119d4ca23541825cf08fa18f542" alt=""
场景一 有限状态机
data:image/s3,"s3://crabby-images/e980f/e980f21fdf51626c827e30722526b88bb8dee4e9" alt=""
import StateMachine from 'javascript-state-machine'
import $ from 'jquery'
console.log(StateMachine,333)
//初始化状态机模型
let fsm = new StateMachine({
init:'收藏',
transitions:[
{
name:'doStore',
from:'收藏',
to:'取消收藏'
},
{
name:'deleteStore',
from:'取消收藏',
to:'收藏'
}
],
methods:{
// 监听执行收藏
onDoStore:function () {
alert('收藏成功')
updateText()
},
// 监听执行取消收藏
onDeleteStore:function(){
alert('取消收藏成功')
updateText()
}
}
})
let $btn = $('#btn1')
$btn.click(function(){
if(fsm.is('收藏')){
fsm.doStore()
}else{
fsm.deleteStore()
}
})
//更新按钮的文案
function updateText(){
$btn.text(fsm.state)
}
//初始化文案
updateText()
实现一个Promise
data:image/s3,"s3://crabby-images/a5692/a5692c6d476f157798ad0bb5192181c093060920" alt=""
data:image/s3,"s3://crabby-images/dbf7d/dbf7d2cfc9db0b46beaeddd364bb8bd54727fb45" alt=""
data:image/s3,"s3://crabby-images/710fe/710fe165920d09ade4ee177b5137178862625089" alt=""
data:image/s3,"s3://crabby-images/9260d/9260d1b866b09205551bc86cf0f840fececd8b8b" alt=""
实现一个购物车
效果图
data:image/s3,"s3://crabby-images/941d1/941d131f0cc70ef3be75b45e8e330feaad2e1cd5" alt=""
UML类图
data:image/s3,"s3://crabby-images/8ed31/8ed31681671c304313c28692c430370912e1398d" alt=""
代码:https://github.com/zzyo96/JSDesignPatterns/tree/master/demo/shoppingCart
网友评论