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 相关文章推荐
form中限制文本字节数js代码
Jun 10 Javascript
js禁止document element对象选中文本实现代码
Mar 21 Javascript
bootstrap3 兼容IE8浏览器!
May 02 Javascript
Javascript实现图片不间断滚动的代码
Jun 22 Javascript
一个超简单的jQuery回调函数例子(分享)
Aug 08 Javascript
20行JS代码实现网页刮刮乐效果
Jun 23 Javascript
使用Webpack提高Vue.js应用的方式汇总(四种)
Jul 10 Javascript
BootStrap导航栏问题记录
Jul 31 Javascript
详解React Native顶|底部导航使用小技巧
Sep 14 Javascript
React SSR样式及SEO的实践
Oct 22 Javascript
Vue项目History模式404问题解决方法
Oct 31 Javascript
js+html5 canvas实现ps钢笔抠图
Apr 28 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/04/27 PHP
基于PHP实现等比压缩图片大小
2016/03/04 PHP
php pdo连接数据库操作示例
2019/11/18 PHP
Laravel框架Blade模板简介及模板继承用法分析
2019/12/03 PHP
js操作Xml(向服务器发送Xml,处理服务器返回的Xml)(IE下有效)
2009/01/30 Javascript
javascript中input中readonly和disabled区别介绍
2012/10/23 Javascript
javascript中eval和with用法实例总结
2015/11/30 Javascript
浏览器环境下JavaScript脚本加载与执行探析之defer与async特性
2016/01/14 Javascript
深入理解Angular2 模板语法
2016/08/07 Javascript
Vue数据驱动模拟实现3
2017/01/11 Javascript
jQuery中的on与bind绑定事件区别实例详解
2017/02/28 Javascript
jQuery中Chosen三级联动功能实例代码
2017/03/07 Javascript
jQuery实现全选、反选和不选功能
2017/08/16 jQuery
JS面向对象的程序设计相关知识小结
2018/05/26 Javascript
jQuery动态移除与增加onclick属性的方法详解
2018/06/07 jQuery
微信小程序开发之改变data中数组或对象的某一属性值
2018/07/05 Javascript
vue中Axios的封装与API接口的管理详解
2018/08/09 Javascript
解决vue动态为数据添加新属性遇到的问题
2018/09/18 Javascript
Javascript中绑定click事件的四种方式介绍
2018/10/26 Javascript
微信小程序实现页面跳转传递参数(实体,对象)
2019/08/12 Javascript
springboot+vue实现文件上传下载
2020/11/17 Vue.js
python使用自定义user-agent抓取网页的方法
2015/04/15 Python
python基础入门学习笔记(Python环境搭建)
2016/01/13 Python
Python中BeautifuSoup库的用法使用详解
2019/11/15 Python
python3 动态模块导入与全局变量使用实例
2019/12/22 Python
浅谈keras中loss与val_loss的关系
2020/06/22 Python
Python tempfile模块生成临时文件和临时目录
2020/09/30 Python
详解CSS3+JS完美实现放大镜模式
2020/12/03 HTML / CSS
西雅图的买手店:Totokaelo
2019/10/19 全球购物
到底Java是如何传递参数的?是by value或by reference?
2012/07/13 面试题
求职自荐信范文格式
2013/11/29 职场文书
银行贷款承诺书
2014/03/29 职场文书
小学班主任寄语大全
2014/04/04 职场文书
小学阳光体育活动总结
2014/07/05 职场文书
写作技巧:如何撰写一份优秀的营销策划书
2019/08/13 职场文书
css 边框添加四个角的实现代码
2021/10/16 HTML / CSS