028-86922220

建站动态

根据您的个性需求进行定制 先人一步 抢占小程序红利时代

web前端中观察者模式的示例分析

这篇文章给大家分享的是有关web前端中观察者模式的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

成都创新互联专注于企业成都全网营销、网站重做改版、仁和网站定制设计、自适应品牌网站建设、html5商城网站定制开发、集团公司官网建设、成都外贸网站制作、高端网站制作、响应式网页设计等建站业务,价格优惠性价比高,为仁和等各大城市提供网站开发制作服务。

观察者模式(Observer Pattern)

观察者模式又称发布-订阅模式(Publish/Subscribe Pattern),是我们经常接触到的设计模式,日常生活中的应用也比比皆是,比如你订阅了某个博主的频道,当有内容更新时会收到推送;又比如JavaScript中的事件订阅响应机制。观察者模式的思想用一句话描述就是:被观察对象(subject)维护一组观察者(observer),当被观察对象状态改变时,通过调用观察者的某个方法将这些变化通知到观察者

观察者模式中Subject对象一般需要实现以下API:

用JavaScript手动实现观察者模式:

// 被观察者function Subject() {
  this.observers = [];}Subject.prototype = {
  // 订阅
  subscribe: function (observer) {
    this.observers.push(observer);
  },
  // 取消订阅
  unsubscribe: function (observerToRemove) {
    this.observers = this.observers.filter(observer => {
      return observer !== observerToRemove;
    })
  },
  // 事件触发
  fire: function () {
    this.observers.forEach(observer => {
      observer.call();
    });
  }}

验证一下订阅是否成功:

const subject = new Subject();function observer1() {
  console.log('Observer 1 Firing!');}function observer2() {
  console.log('Observer 2 Firing!');}subject.subscribe(observer1);subject.subscribe(observer2);subject.fire();
  //输出:Observer 1 Firing! Observer 2 Firing!

验证一下取消订阅是否成功:

subject.unsubscribe(observer2);subject.fire();//输出:Observer 1 Firing!

场景

document.body.addEventListener('click', function() {
    console.log('hello world!');});document.body.click()

优点

缺点

感谢各位的阅读!关于“web前端中观察者模式的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!


本文标题:web前端中观察者模式的示例分析
当前地址:http://www.tsicrk.com/article/gpedce.html

其他资讯

让你的专属顾问为你服务

1.7530s