观察者模式 & 发布-订阅模式(设计模式与开发实践 P8)

文章目录

观察者模式

定义:他用来定义对象之间一种一对多的依赖关系,当一个对象状态发生改变时,所有依赖他的对象都会得到通知

运用

如果我们使用过 DOM 上的事件函数,那就接触过观察者模式

javascript 复制代码
document.body.addEventListener(
  "click",
  function () {
    console.log("body clicked");
  },
  false
);

document.body.click(); // 输出:body clicked

这段代码中 body 上添加了一个订阅者,而 document.body.click() 向所有订阅者发送了点击事件~

我们可以随意添加 订阅者 而不会影响 发布者 代码的编写

实现

接下来尝试实现一些自定义事件,通过 listen 监听某个名为 key 的事件,通过 trigger 执行事件回调函数

javascript 复制代码
var saleOffices = {
  clientList: [], // 缓存列表,存放订阅者的回调函数
  listen: function (key, fn) {
    // 增加订阅者
    if (!this.clientList[key]) {
      // 如果还没有订阅过此类消息,给该类消息创建一个缓存列表
      this.clientList[key] = []; // 直接把函数推入数组
    }
    this.clientList[key].push(fn); // 订阅的消息添加进缓存列表
  },
  trigger: function () {
    // 发布消息
    var key = Array.prototype.shift.call(arguments); // 取出消息类型
    var fns = this.clientList[key]; // 取出该消息对应的回调函数集合
    if (!fns || fns.length === 0) {
      // 如果没有订阅该消息,则返回
      return false;
    }
    for (var i = 0, fn; (fn = fns[i++]); ) {
      // 依次执行订阅的回调函数
      fn.apply(this, arguments); // arguments 是发布消息时带上的参数
    }
  },
};

// ----- 测试 -----
saleOffices.listen("squareMeter88", function (price) {
  // 小明订阅消息
  console.log("小明得到价格= " + price);
});

saleOffices.listen("squareMeter100", function (price) {
  // 小红订阅消息
  console.log("小红价格= " + price);
});

saleOffices.trigger("squareMeter88", 2000000); // 输出:2000000
相关推荐
程序员_三木几秒前
Three.js入门-Raycaster鼠标拾取详解与应用
开发语言·javascript·计算机外设·webgl·three.js
码农爱java1 小时前
设计模式--抽象工厂模式【创建型模式】
java·设计模式·面试·抽象工厂模式·原理·23种设计模式·java 设计模式
开心工作室_kaic2 小时前
springboot476基于vue篮球联盟管理系统(论文+源码)_kaic
前端·javascript·vue.js
川石教育2 小时前
Vue前端开发-缓存优化
前端·javascript·vue.js·缓存·前端框架·vue·数据缓存
搏博2 小时前
使用Vue创建前后端分离项目的过程(前端部分)
前端·javascript·vue.js
温轻舟2 小时前
前端开发 之 12个鼠标交互特效上【附完整源码】
开发语言·前端·javascript·css·html·交互·温轻舟
越甲八千2 小时前
重温设计模式--中介者模式
windows·设计模式·中介者模式
web135085886352 小时前
2024-05-18 前端模块化开发——ESModule模块化
开发语言·前端·javascript
犬余2 小时前
设计模式之桥接模式:抽象与实现之间的分离艺术
笔记·学习·设计模式·桥接模式
LCG元3 小时前
javascript页面设计案例【使用HTML、CSS和JavaScript创建一个基本的互动网页】
javascript