美文网首页
观察者模式 - 演示与场景

观察者模式 - 演示与场景

作者: EmilWong | 来源:发表于2019-06-10 11:54 被阅读0次
  • 发布&订阅
  • 一对多/一对一
    UML类图:


    image.png

代码演示:

// 主题、保存状态,状态变化之后触发所有观察者模式
class Subject{
    constructor() {
        this.state = 0
        this.observers = []
    }
    getState(){
        return this.state
    }
    setState(state){
        this.state = state
        this.notifyAllObservers()
    }
    notifyAllObservers(){
        this.observers.forEach(observer => {
            observer.update()
        })
    }
    attach(observer){
        this.observers.push(observer)
    }
}
// 观察者
class Observer {
    constructor(name, subject){
        this.name = name
        this.subject = subject
        this.subject.attach(this)
    }
    update(){
        console.log(`${this.name} update, state: ${this.subject.getState()} `)
    }
}

// 测试
let s = new Subject()
let o1 = new Observer('o1', s)
let o2 = new Observer('o2', s)
let o3 = new Observer('o3', s)

s.setState(1)
s.setState(2)
s.setState(3)

使用场景:
网页事件绑定

$('#btn').click(function(){
  console.log(1)
})
$('#btn').click(function(){
  console.log(2)
})
$('#btn').click(function(){
  console.log(3)
})

Promise
三种状态:pending、fulfilled、rejected
jQuery callbacks

// 自定义事件,自定义回调
var callbacks = $.Callbacks()
callbacks.add(function(info){
  console.log('fn1', info)
})
callbacks.add(function(info){
  console.log('fn2', info)
})
callbacks.add(function(info){
  console.log('fn3', info)
})

nodejs自定义事件

相关文章

  • 观察者模式 - 演示与场景

    发布&订阅 一对多/一对一UML类图:image.png 代码演示: 使用场景:网页事件绑定 Promise三种状...

  • 外观模式 - 演示与场景

    UML类图: 使用场景:业务场景,多个子系统代码演示: 不符合单一职责原则和开放封闭原则,因此谨慎使用,不可随意调用

  • 代理模式 - 演示与场景

    使用场景 VPN代理 SSR UML类图 代码演示: JS使用场景 网页事件代理 jQuery $.proxy E...

  • 状态模式 - 演示与场景

    一个对象有状态变化 每次状态变化都会触发一个逻辑 不能总是if..else来控制

  • 工厂模式 - 演示与场景

    UML类图: 代码模拟: 实例:React.createElement 工厂模式设计原则: 构造函数和创建者分离 ...

  • 设计模式-观察者模式 发布/订阅模式

    设计模式-观察者模式 发布/订阅模式 代码 观察者接口 具体的被观察者 观察者 最后定义中间 场景类 修改 由于上...

  • 装饰器模式 - 演示与场景

    为对象添加新功能 不改变其原有的结构和功能 UML类图: 使用场景:core-decorators API 下一个...

  • 迭代器模式 - 演示与场景

    顺序访问一个集合 使用者无需知道集合的内部结构(封装)UML类图:image.png代码演示: 使用场景:jQue...

  • 单例模式 - 演示与场景

    系统中被唯一使用 一个类只有一个实例示例: 登录框 购物车 UML类图 代码演示: 使用场景:jQuery只有一个...

  • Java - 事件处理机制

    Java - 事件处理机制 一、观察者模式 了解事件和监听,需要先了解观察者模式。 接下来介绍一个观察者模式的场景...

网友评论

      本文标题:观察者模式 - 演示与场景

      本文链接:https://www.haomeiwen.com/subject/atnaxctx.html