电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

javascript設計模式 ? 觀察者模式原理與用法實例分析

瀏覽:59日期:2023-11-02 14:54:02

本文實例講述了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.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 慈溪麦田广告公司,提供慈溪广告设计。 | 全自动实验室洗瓶机,移液管|培养皿|进样瓶清洗机,清洗剂-广州摩特伟希尔机械设备有限责任公司 | 酒糟烘干机-豆渣烘干机-薯渣烘干机-糟渣烘干设备厂家-焦作市真节能环保设备科技有限公司 | 鑫铭东办公家具一站式定制采购-深圳办公家具厂家直销 | 广州展览制作工厂—[优简]直营展台制作工厂_展会搭建资质齐全 | 本安接线盒-本安电路用接线盒-本安分线盒-矿用电话接线盒-JHH生产厂家-宁波龙亿电子科技有限公司 | 专业音响设备_舞台音响设备_会议音响工程-首选深圳一禾科技 | 机械立体车库租赁_立体停车设备出租_智能停车场厂家_春华起重 | 日本细胞免疫疗法_肿瘤免疫治疗_NK细胞疗法 - 免疫密码 | 高低温万能试验机_拉力试验机_拉伸试验机-馥勒仪器科技(上海)有限公司 | 动库网动库商城-体育用品专卖店:羽毛球,乒乓球拍,网球,户外装备,运动鞋,运动包,运动服饰专卖店-正品运动品网上商城动库商城网 - 动库商城 | 净化车间_洁净厂房_净化公司_净化厂房_无尘室工程_洁净工程装修|改造|施工-深圳净化公司 | 茶楼装修设计_茶馆室内设计效果图_云臻轩茶楼装饰公司 | 不锈钢散热器,冷却翅片管散热器厂家-无锡市烨晟化工装备科技有限公司 | 汕头市盛大文化传播有限公司,www.11400.cc | 液压油缸生产厂家-山东液压站-济南捷兴液压机电设备有限公司 | 北京银联移动POS机办理_收银POS机_智能pos机_刷卡机_收银系统_个人POS机-谷骐科技【官网】 | 元拓建材集团官方网站| 兰州UPS电源,兰州山特UPS-兰州万胜商贸| 塑钢课桌椅、学生课桌椅、课桌椅厂家-学仕教育设备首页 | 粉末冶金-粉末冶金齿轮-粉末冶金零件厂家-东莞市正朗精密金属零件有限公司 | 小型铜米机-干式铜米机-杂线全自动铜米机-河南鑫世昌机械制造有限公司 | 专业的新乡振动筛厂家-振动筛品质保障-环保振动筛价格—新乡市德科筛分机械有限公司 | 有机肥设备生产制造厂家,BB掺混肥搅拌机、复合肥设备生产线,有机肥料全部加工设备多少钱,对辊挤压造粒机,有机肥造粒设备 -- 郑州程翔重工机械有限公司 | 东莞注册公司-代办营业执照-东莞公司注册代理记账-极刻财税 | 医用酒精_84消毒液_碘伏消毒液等医用消毒液-漓峰消毒官网 | 专业生物有机肥造粒机,粉状有机肥生产线,槽式翻堆机厂家-郑州华之强重工科技有限公司 | IIS7站长之家-站长工具-爱网站请使用IIS7站长综合查询工具,中国站长【WWW.IIS7.COM】 | 专业生物有机肥造粒机,粉状有机肥生产线,槽式翻堆机厂家-郑州华之强重工科技有限公司 | 客服外包专业服务商_客服外包中心_网萌科技| 大白菜官网,大白菜winpe,大白菜U盘装系统, u盘启动盘制作工具 | 合肥仿石砖_合肥pc砖厂家_合肥PC仿石砖_安徽旭坤建材有限公司 | 全国国际学校排名_国际学校招生入学及学费-学校大全网 | CE认证_FCC认证_CCC认证_MFI认证_UN38.3认证-微测检测 CNAS实验室 | 有声小说,听书,听小说资源库-听世界网| 隧道窑炉,隧道窑炉厂家-山东艾瑶国际贸易 | VOC检测仪-甲醛检测仪-气体报警器-气体检测仪厂家-深恒安科技有限公司 | 细砂提取机,隔膜板框泥浆污泥压滤机,螺旋洗砂机设备,轮式洗砂机械,机制砂,圆锥颚式反击式破碎机,振动筛,滚筒筛,喂料机- 上海重睿环保设备有限公司 | 石磨面粉机|石磨面粉机械|石磨面粉机组|石磨面粉成套设备-河南成立粮油机械有限公司 | 复合土工膜厂家|hdpe防渗土工膜|复合防渗土工布|玻璃纤维|双向塑料土工格栅-安徽路建新材料有限公司 | 北京律师事务所_房屋拆迁律师_24小时免费法律咨询_云合专业律师网 |