觀察者模式

// 被觀察者
class Subject{
    constructor(name){
        this.name = name
        this.state = "開心的"
        this.observer = []
    }

    updateState(state){
        this.state = state
        // 通知觀察者更新
        this.observer.forEach(item=>item.update(this))
    }

    attach(o){
        this.observer.push(o)
    }
}

// 觀察者
class Oberserver{
    constructor(name){
        this.name = name
    }

    update(person){
        console.log(`${this.name}發(fā)現(xiàn)${person.name}狀態(tài)變?yōu)?{person.state}`)
    }
}

let baby = new Subject('baby')
let father = new Oberserver("father")
let mather = new Oberserver("mather")
baby.attach(father)
baby.attach(mather)

setTimeout(function(){
    baby.updateState("哭了")
},3000)

setTimeout(function(){
    baby.updateState("再跑。。。")
},5000)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容