设计模式-观察者模式
乔文飞 Lv8

简单介绍一下

观察者模式,又称发布/订阅模式,它定义了一种一对多的关系,让多个观察者对象同时监听某一个主题对象,这个主题对象的状态发生变化时就会通知所有的观察者对象,使得它们能够自动更新自己。

使用观察者模式的好处:

  • 支持简单的广播通信,自动通知所有已经订阅过的对象。
  • 页面载入后目标对象很容易与观察者存在一种动态关联,增加了灵活性。
  • 目标对象与观察者之间的抽象耦合关系能够单独扩展以及重用。

用javaScript实现一般简单的观察者模式

pub(Publish) 发布
sub(Subscribe) 订阅
dep 发布订阅中心-电话本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
var dep = {};  // dep相当于电话本,所有订阅者都注册在这里
(function (q) {
var topics = {}, // 回调函数存放的数组
subUid = -1;
// 发布方法
q.publish = function (topic, args) {
if (!topics[topic]) {
return false;
}
setTimeout(function () {
var subscribers = topics[topic],
len = subscribers ? subscribers.length : 0;

while (len--) {
// 遍历所有订阅的方法,全部执行
subscribers[len].func(topic, args);
}
}, 0);

return true;

};
// 订阅方法
// @param topic 订阅者名称
// @param func 订阅方法,通知时,调用这个方法实现通知
q.subscribe = function (topic, func) {
if (!topics[topic]) {
// 注册观察对象
topics[topic] = [];
}
var token = (++subUid).toString(); // 方法的唯一口令标识,退订时可用
// 注册观察方法
topics[topic].push({
token: token,
func: func
});
return token;
};
//退订方法
q.unsubscribe = function (token) {
for (var m in topics) {
if (topics[m]) {
for (var i = 0, j = topics[m].length; i < j; i++) {
if (topics[m][i].token === token) {
// 根据唯一口令标识 移除观察方法,实现退订
topics[m].splice(i, 1);
return token;
}
}
}
}
return false;
};
} (dep));

使用上面这个观察者模式

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
// 来,订阅一个
pubsub.subscribe('example1', function (topics, data) {
// 通知时,这个方法收到通知执行
console.log(topics + ": " + data);
})
// 再加一个订阅方法
pubsub.subscribe('example1', function (topics, data) {
// 这个方法也收到通知执行
if(!Array.isArray(data)){
console.log('接到通知2',topics, data)
}
})
//发布通知
pubsub.publish('example1', 'hello world!');
pubsub.publish('example1', ['test', 'a', 'b', 'c']);
pubsub.publish('example1', [{ 'color': 'blue' }, { 'text': 'hello'}]);

一张图说清楚观察者模式

观察者模式

特别鸣谢

此篇笔记是看了汤姆大叔的博客-深入理解JavaScript系列(32):设计模式之观察者模式,笔记内容大多来自该篇博客。大叔的博客中还有其他观察者模式的实现方式,如需更深的理解,请移步。

  • 本文标题:设计模式-观察者模式
  • 本文作者:乔文飞
  • 创建时间:2020-08-12 09:24:58
  • 本文链接:http://www.feidom.com/2020/08/12/观察者模式/
  • 版权声明:本博客所有文章为作者学习笔记,有转载其他前端大佬的文章。转载时请注明出处。