事件分析:一對多,觀察者模式
1.建立事件倉庫:obj{key:val,key:val}
2.事件綁定(name,fn):先判斷事件名稱name在事件倉庫中是否存在,不存在,則初始化obj[name]=[];將需要綁定的事件push進數組中.
3.事件觸發(name,val):先判斷事件名稱name在事件倉庫中是否存在,存在則遍歷數組每個fn元素,調用事件;val為傳遞的參數.
4.事件移除(name,fn):先判斷事件名稱name在事件倉庫中是否存在,再判斷fn是否有,最后判斷fn是否存在數組中,存在則刪除fn數組元素;若無fn則清空數組.
原生js封裝事件:
let obj = {}; const $on = (name,fn)=>{ if(!obj[name]){ obj[name] = []; } obj[name].push(fn); } const $emit = (name,val)=>{ if(obj[name]){ obj[name].map((fn)=>{ fn(val); }); } } const $off = (name,fn)=>{ if(obj[name]){ if(fn){ let index = obj[name].indexOf(fn); if(index > -1){ obj[name].splice(index,1); } }else{ obj[name].length = 0; //設長度為0比obj[name] = []更優,因為如果是空數組則又開辟了一個新空間,設長度為0則不必開辟新空間 } } } export default { $on, $emit, $off }