您的位置:首页 > 汽车 > 时评 > 【设计模式】工厂模式、单例模式、观察者模式、发布订阅模式

【设计模式】工厂模式、单例模式、观察者模式、发布订阅模式

2024/9/19 9:49:22 来源:https://blog.csdn.net/nakyoooooo/article/details/142349748  浏览:    关键词:【设计模式】工厂模式、单例模式、观察者模式、发布订阅模式

1.工厂模式

class Factory{createProduct(name){return new Product(name);}
}
class Product{constructor(name){this.name=name;}display(){console.log(`product:${this.name}`);}
}//使用
const factory=new Factory();
const p1=factory.createProduct('P1');
const p2=factory.createProduct('P2');
p1.display()
p2.display()

2.单例模式

class Singleton{static instance=null;constructor(){if(Singleton.instance){return Singleton.instance}Singleton.instance=this;}
}//使用
const instance1=new Singleton()
const instance2=new Singleton()

3.观察者模式

class Subject{constructor(){this.observers=[];}addObserver(observer){this.observers.push(observer);}removerObserver(observer){this.observers=this.observers.filter(obs=>obs!==observer);}notifyObserver(){this.observers.forEach(obs=>obs.update());}
}class Observer{constructor(name){this.name=name;}update(){console.log(`Observer ${this.name} has been notified`);}
}
//使用
const subject=new Subject();
const observer1=new Observer('1');
const observer2=new Observer('2');
subject.addObserver(observer1);
subject.addObserver(observer2);
subject.notifyObserver();

4.发布订阅模式

class Broker{constructor(){this.subscribers=[];this.state=0;}subscribe(subscriber){this.subscribers.push(subscriber);}setState(state){this.state=state;this.publish();}getState(){return this.state;}publish(){this.subscribers.forEach(sub=>sub.update());}
}class Publisher{constructor(){}changeState(broker,state){broker.setState(state);}
}class Subscriber{constructor(name,broker){this.name=name;this.broker=broker;this.broker.subscribe(this);}update(){console.log(`${this.name}:${this.broker.getState()}`);}
}
//使用
const broker=new Broker();
const publish=new Publisher();
const subscribe1=new Subscriber('s1',broker);
const subscribe2=new Subscriber('s2',broker);
publish.changeState(broker,1);

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com