觀察者(又稱發(fā)布訂閱)模式定義了對象間的一種一對多的依賴關系,以便一個對象的狀態(tài)發(fā)生變化時,所有依賴于它的對象都得到通知并自動刷新。
當用戶在網頁執(zhí)行一些操作(如點擊)后就需要執(zhí)行一些預定的事件(如表單提交、跳轉頁面)
優(yōu)點:在發(fā)布者和訂閱者間耦合性降低
缺點:弱化了對象間的關系,不利于代碼的維護和理解
實現思路
確定發(fā)布者
定義發(fā)布者緩存列表,存儲回調函數通知訂閱者
發(fā)布消息依次執(zhí)行緩存列表回調函數
簡單實現
let event = {}; event.list = [];//增加訂閱者event.listen = function(fn){ event.list.push(fn); }//發(fā)布消息event.trigger = function(){ for(var i = 0,fn; fn = this.list[i++];) { fn.apply(this,arguments); } }let click = function(){ console.log('event:click'); }let hover = function(){ console.log('event:hover'); } event.listen(click); event.listen(hover); event.trigger();//打印:‘event:click’'event:hover'
完善觀察者模式
let Event = (function(){ var list = {}, listen, trigger, remove; listen = function(key,fn){ list[key] = list[key]||[]; list[key].push(fn); }; trigger = function(){ var key = Array.prototype.shift.call(arguments), fns = list[key]; if(!fns || fns.length === 0) { return false; } for(var i = 0, fn; fn = fns[i++];) { fn.apply(this,arguments); } }; remove = function(key,fn){ var fns = list[key]; if(!fns) { return false; } if(!fn) { fns && (fns.length = 0); }else { for(var i = fns.length - 1; i >= 0; i--){ var _fn = fns[i]; if(_fn === fn) { fns.splice(i,1); } } } }; return { listen: listen, trigger: trigger, remove: remove } })(); Event.listen('click', function(type) { console.log('event: ' + type +' click'); }); Event.trigger('click' , 'button');//打印'event: button click'
觀察者模式可以用于模塊間通訊,訂閱用戶的事件、狀態(tài),觸發(fā)執(zhí)行相應的邏輯處理。
相信看了本文案例你已經掌握了方法,更多精彩請關注Gxl網其它相關文章!
推薦閱讀:
Javascript的代理模式
Javascript的策略模式
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com