Javascript设计模式之观察者模式(推荐)


Posted in Javascript onMarch 29, 2016

推荐阅读: JavaScript观察者模式(经典)

1.什么是观察者模式

观察者模式有时也称为发布--订阅模式,在观察者模式中,有一个观察者可以管理所有的目标,等到有状态发生改变的时候发出通知。(其实sql server中的发布订阅也是这个道理)

2.通俗解释

假如以前村里的广播是一个观察者,那么每个村民就是被观察对象,如果村子里有通知,政策发生改变的时候,就需要通过广播把这个消息发布出去,而不用直接一家家的跑去发通知。

3.代码

<!DOCTYPE html> 
<html lang="en"> 
<head> 
<meta charset="UTF-8"> 
<title>观察者模式</title> 
</head> 
<body> 
<script> 
var observer = {//观察者 
villagers: [],//村名 
addVillager: function (callback) {//增加村名 
this.villagers[this.villagers.length] = callback; 
}, 
removeVillager: function (callback) {//移除村名 
for (var i = 0; i < this.villagers.length; i++) { 
if (this.villagers[i] === callback) { 
delete this.villagers[i]; 
} 
} 
}, 
publish: function (info) {//发布信息 
for (var i = 0; i < this.villagers.length; i++) { 
if (typeof this.villagers[i] === 'function') { 
this.villagers[i](info); 
} 
} 
}, 
make: function (o) {//这里将村子建一个这种广播方式 
for (var i in this) { 
o[i] = this[i]; 
} 
} 
}; 
var village1 = {}; 
observer.make(village1);//将村子1建立这种观察者模式 
var villager11 = { 
read: function (what) { 
console.log('我是第一个村子的第一个村名:' + what); 
} 
}; 
var villager12 = { 
read: function (what) { 
console.log('我是第一个村子的第二个村名:'+what); 
} 
}; 
village1.addVillager(villager11.read); 
village1.addVillager(villager12.read); 
village1.publish('大家来开会呀!!!'); 
village1.removeVillager(villager11.read); 
village1.publish('大家来开会呀!!!'); 
/* var village2 = { 
myAddVillager:function(callback){ 
this.addVillager(callback); 
}, 
myRemoveVillager:function(callback){ 
this.removeVillager(callback); 
}, 
myPublish:function(info){ 
this.publish(info); 
} 
}; 
observer.make(village2);//将村子1建立这种观察者模式 
var villager21 = { 
read: function (what) { 
console.log('我是第二个村子的第一个村名:' + what); 
} 
}; 
var villager22 = { 
read: function (what) { 
console.log('我是第二个村子的第二个村名:'+what); 
} 
}; 
village2.myAddVillager(villager21.read); 
village2.myAddVillager(villager22.read); 
village2.myPublish('大家来领猪肉了!!!');*/ 
</script> 
</body> 
</html>

写到这里观察者模式实现了,但是可能会有多个村子需要这种模式,那我们这里将observer改造成构造函数的方式

<!DOCTYPE html> 
<html lang="en"> 
<head> 
<meta charset="UTF-8"> 
<title>观察者模式</title> 
</head> 
<body> 
<script> 
function Observer(){//观察者,这里采用构造函数,可以对不同村落进行使用 
if(!(this instanceof Observer)){ 
return new Observer(); 
} 
this.villagers = []; 
}; 
Observer.prototype = { 
// villagers: [],//村名 
addVillager: function (callback) {//增加村名 
this.villagers[this.villagers.length] = callback; 
}, 
removeVillager: function (callback) {//移除村名 
for (var i = 0; i < this.villagers.length; i++) { 
if (this.villagers[i] === callback) { 
delete this.villagers[i]; 
} 
} 
}, 
publish: function (info) {//发布信息 
for (var i = 0; i < this.villagers.length; i++) { 
if (typeof this.villagers[i] === 'function') { 
this.villagers[i](info); 
} 
} 
}, 
make: function (o) {//这里将村子建一个这种广播方式 
for (var i in this) { 
o[i] = this[i]; 
} 
} 
} 
var village1 = {}; 
var observer1 = new Observer(); 
observer1.make(village1);//将村子1建立这种观察者模式 
var villager11 = { 
read: function (what) { 
console.log('我是第一个村子的第一个村名:' + what); 
} 
}; 
var villager12 = { 
read: function (what) { 
console.log('我是第一个村子的第二个村名:'+what); 
} 
}; 
village1.addVillager(villager11.read); 
village1.addVillager(villager12.read); 
village1.publish('大家来开会呀!!!'); 
village1.removeVillager(villager11.read); 
village1.publish('大家来开会呀!!!'); 
var village2 = { 
myAddVillager:function(callback){ 
this.addVillager(callback); 
}, 
myRemoveVillager:function(callback){ 
this.removeVillager(callback); 
}, 
myPublish:function(info){ 
this.publish(info); 
} 
}; 
var observer2 = new Observer(); 
observer2.make(village2);//将村子1建立这种观察者模式 
var villager21 = { 
read: function (what) { 
console.log('我是第二个村子的第一个村名:' + what); 
} 
}; 
var villager22 = { 
read: function (what) { 
console.log('我是第二个村子的第二个村名:'+what); 
} 
}; 
village2.myAddVillager(villager21.read); 
village2.myAddVillager(villager22.read); 
village2.myPublish('大家来领猪肉了!!!'); 
</script> 
</body> 
</html>

有关Javascript设计模式之观察者模式小编就给大家介绍到这里,希望对大家有所帮助!

Javascript 相关文章推荐
javascript 短路法代码精简
Aug 20 Javascript
Javascript 加载和执行-性能提高篇
Dec 28 Javascript
jquery移动listbox的值原理及代码
May 03 Javascript
jquery滚动加载数据的方法
Mar 09 Javascript
谈谈javascript中使用连等赋值操作带来的问题
Nov 26 Javascript
js点击返回跳转到指定页面实现过程
Aug 20 Javascript
详解jQuery的表单验证插件--Validation
Dec 21 Javascript
BootStrap Table对前台页面表格的支持实例讲解
Dec 22 Javascript
自定义vue全局组件use使用、vuex的使用详解
Jun 14 Javascript
详解vue 数组和对象渲染问题
Sep 21 Javascript
微信小程序实现点击效果
Jun 21 Javascript
jquery实现直播弹幕效果
Nov 28 jQuery
AngularJS directive返回对象属性详解
Mar 28 #Javascript
Boostrap模态窗口的学习小结
Mar 28 #Javascript
理解javascript模块化
Mar 28 #Javascript
谈一谈jQuery核心架构设计
Mar 28 #Javascript
javascript函数自动执行常用方法汇总
Mar 28 #Javascript
JavaScript利用HTML DOM进行文档操作的方法
Mar 28 #Javascript
JavaScript常用本地对象小结
Mar 28 #Javascript
You might like
PHP得到mssql的存储过程的输出参数功能实现
2012/11/23 PHP
PHP中VC6、VC9、TS、NTS版本的区别与用法详解
2013/10/26 PHP
PHP中session变量的销毁
2014/02/27 PHP
ThinkPHP设置禁止百度等搜索引擎转码(简单实用)
2016/02/15 PHP
php实现的简单数据库操作Model类
2016/11/16 PHP
用Jquery实现多级下拉框无刷新的联动
2010/12/22 Javascript
用Mootools获得操作索引的两种方法分享
2011/12/12 Javascript
jquery 合并内容相同的单元格(示例代码)
2013/12/13 Javascript
解决jquery中美元符号命名冲突问题
2014/01/08 Javascript
setInterval与clearInterval的使用示例代码
2014/01/28 Javascript
js+jquery常用知识点汇总
2015/03/03 Javascript
基于Css3和JQuery实现打字机效果
2015/08/11 Javascript
解决浏览器会自动填充密码的问题
2017/04/28 Javascript
mac下的nodejs环境安装的步骤
2017/05/24 NodeJs
JS实现上传图片的三种方法并实现预览图片功能
2017/07/14 Javascript
Vue filter介绍及其使用详解
2017/10/21 Javascript
详解vue移动端日期选择组件
2018/02/22 Javascript
如何使node也支持从url加载一个module详解
2018/06/05 Javascript
webpack开发环境和生产环境的深入理解
2018/11/08 Javascript
如何获取vue单文件自身源码路径
2019/05/06 Javascript
微信小程序页面调用自定义组件内的事件详解
2019/09/12 Javascript
ES5新增数组的实现方法
2020/05/12 Javascript
Python中内置数据类型list,tuple,dict,set的区别和用法
2015/12/14 Python
Django实现表单验证
2018/09/08 Python
python脚本当作Linux中的服务启动实现方法
2019/06/28 Python
python opencv捕获摄像头并显示内容的实现
2019/07/11 Python
Python多线程多进程实例对比解析
2020/03/12 Python
Python+Selenium实现自动化的环境搭建的步骤(图文)
2020/09/01 Python
python 操作excel表格的方法
2020/12/05 Python
初中军训感想300字
2014/03/05 职场文书
个人贷款担保书
2014/04/01 职场文书
俞敏洪北大演讲稿
2014/05/22 职场文书
婚礼长辈答谢词
2015/09/29 职场文书
2019年英语版感谢信(8篇)
2019/09/29 职场文书
Spring Cloud Netflix 套件中的负载均衡组件 Ribbon
2022/04/13 Java/Android
python井字棋游戏实现人机对战
2022/04/28 Python