javascript设计模式 ? 观察者模式原理与用法实例分析


Posted in Javascript onApril 22, 2020

本文实例讲述了javascript设计模式 ? 观察者模式原理与用法。分享给大家供大家参考,具体如下:

介绍:前面我们针对系统内一对多,多对多的情况做了解决方案,是使用中介者模式,将所有关联关系交由中介者处理。这一节我们介绍另外一种解决一对多问题的设计模式:观察者模式
观察者模式是使用频率最高的设计模式之一,用于建立一种对象与对象之间的依赖关系。

定义:定义对象之间的之间的一种一对多依赖关系,使得每当一个对象状态发生改变时,其相关依赖对象皆得到通知并被自动更新。观察者模式的别名包括发布-订阅模式,模型-视图模式,监听模式或从属模式。观察者模式是一种对象行为型模式。

场景:我们使用观察者模式做一个进制转换的小demo

示例:

var Subject = function(){
  var obServer = [];
  var _state;
 
  this.getState = function(){
    return _state;
  }
  this.setState = function(state){
    _state = state;
    this.notifyAllObservers();
  }
  this.attach = function(ob){
    obServer.push(ob);
  }
  this.notifyAllObservers = function(){
    obServer.map(function(item){
      item.update();
    });
  }
}
 
var BinaryObserver = function(subject){
  var _subject = subject;
  _subject.attach(this);
 
  this.update = function(){
    console.log('Binary String:' + _subject.getState().toString(2));
  }
}
 
var OctalObserver = function(subject){
  var _subject = subject;
  _subject.attach(this);
 
  this.update = function(){
    console.log('Octal String:' + _subject.getState().toString(8));
  }
}
 
var HexaObserver = function(subject){
  var _subject = subject;
  _subject.attach(this);
 
  this.update = function(){
    console.log('Hex String:' + _subject.getState().toString(16));
  }
}
 
var subject = new Subject();
 
new HexaObserver(subject);
new OctalObserver(subject);
new BinaryObserver(subject);
 
subject.setState(15);
// Hex String:f
// Octal String:17
// Binary String:1111

在这个例子里面Subject称为目标,它是被观察的对象,一个目标允许被多个观察者观察,这些观察者存放于obServer的数组中,当目标发生change时通知所有观察者。
BinaryObserver,OctalObserver,HexaObserver这三个类称为观察者,观察者将对目标的改变作出反应。在观察者中需要维护一个指向目标对象的引用。

观察者模式总结:

优点:
* 观察者模式可以实现表示层和数据逻辑层的分离,定义了稳定的消息更新传递机制。
* 观察者模式在观察目标和观察者者之间建立一个抽象的耦合。观察目标只需要维持一个抽象观察者的集合,无需了解其具体观察者。
* 观察者模式支持广播通信,观察目标会向所有已注册的观察者发送通知,简化了一对多系统的设计难度

缺点:
* 在存在大量观察者时,对所有观察者的通知会花大量时间
* 如果观察者和目标之间存在循环依赖,将会导致系统崩溃

适用场景:
* 系统中存在一个对象的改变将导致一个或多个其他对象也发生改变。
* 系统中存在大量依赖链,A影响B,B影响C,C影响D

感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具:http://tools.3water.com/code/HtmlJsRun测试上述代码运行效果。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
浅析showModalDialog数据缓存问题(用禁止浏览器缓存解决)
Jul 09 Javascript
jQuery插件EnPlaceholder实现输入框提示文字
Jun 05 Javascript
jQuery on()方法示例及jquery on()方法的优点
Aug 27 Javascript
JS模拟酷狗音乐播放器收缩折叠关闭效果代码
Oct 29 Javascript
Node.js Addons翻译(C/C++扩展)
Jun 12 Javascript
浅谈js中的三种继承方式及其优缺点
Aug 10 Javascript
微信小程序媒体组件详解(视频,音乐,图片)
Sep 19 Javascript
React数据传递之组件内部通信的方法
Dec 31 Javascript
jQuery获取随机颜色的实例代码
May 21 jQuery
Node.js之删除文件夹(含递归删除)代码实例
Sep 09 Javascript
vue中 数字相加为字串转化为数值的例子
Nov 07 Javascript
webpack+vue.js构建前端工程化的详细教程
May 10 Javascript
javascript设计模式 ? 状态模式原理与用法实例分析
Apr 22 #Javascript
Vue computed 计算属性代码实例
Apr 22 #Javascript
js 解析 JSON 数据简单示例
Apr 21 #Javascript
react 原生实现头像滚动播放的示例
Apr 21 #Javascript
解决angular 使用原生拖拽页面卡顿及表单控件输入延迟问题
Apr 21 #Javascript
javascript设计模式 ? 策略模式原理与用法实例分析
Apr 21 #Javascript
javascript设计模式 ? 备忘录模式原理与用法实例分析
Apr 21 #Javascript
You might like
如何判断php数组的维度
2013/06/10 PHP
PHP中怎样保持SESSION不过期 原理及方案介绍
2013/08/08 PHP
PHP抓取、分析国内视频网站的视频信息工具类
2014/04/02 PHP
php中动态修改ini配置
2014/10/14 PHP
php生成短域名函数
2015/03/23 PHP
Yii框架结合sphinx,Ajax实现搜索分页功能示例
2016/10/18 PHP
PHP面向对象之领域模型+数据映射器实例(分析)
2017/06/21 PHP
javascript 获取HTML DOM父、子、临近节点
2014/06/16 Javascript
关于编写性能高效的javascript事件的技术
2014/11/28 Javascript
jquery实现简单的无缝滚动
2015/04/15 Javascript
详细分析JS函数去抖和节流
2017/12/05 Javascript
vue-cli项目无法用本机IP访问的解决方法
2018/09/20 Javascript
JavaScript日期库date-fn.js使用方法解析
2020/09/09 Javascript
[01:59]DOTA2首部纪录片《Free to play》预告片
2014/03/12 DOTA
Python实现删除文件但保留指定文件
2015/06/21 Python
Python使用正则表达式获取网页中所需要的信息
2018/01/29 Python
解决Python3.5+OpenCV3.2读取图像的问题
2018/12/05 Python
Python给定一个句子倒序输出单词以及字母的方法
2018/12/20 Python
python使用MQTT给硬件传输图片的实现方法
2019/05/05 Python
Python 中的参数传递、返回值、浅拷贝、深拷贝
2019/06/25 Python
Django框架获取form表单数据方式总结
2020/04/22 Python
PyPDF2读取PDF文件内容保存到本地TXT实例
2020/05/12 Python
浅谈keras中自定义二分类任务评价指标metrics的方法以及代码
2020/06/11 Python
CentOS 7如何实现定时执行python脚本
2020/06/24 Python
Django静态文件加载失败解决方案
2020/08/26 Python
Python性能测试工具Locust安装及使用
2020/12/01 Python
python中_del_还原数据的方法
2020/12/09 Python
html5的localstorage详解
2017/05/09 HTML / CSS
Ray-Ban雷朋太阳眼镜英国官网:Ray-Ban UK
2019/11/23 全球购物
口腔工艺技术专业毕业生自荐信
2013/09/27 职场文书
业务主管岗位职责范本
2013/12/25 职场文书
大学生军训自我鉴定
2014/02/12 职场文书
求职信怎么写范文
2014/05/26 职场文书
2014年骨干教师工作总结
2014/12/19 职场文书
MySQL创建管理LIST分区
2022/04/13 MySQL
JS实现页面炫酷的时钟特效示例
2022/08/14 Javascript