事件分析:一对多,观察者模式
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 }