zoukankan      html  css  js  c++  java
  • JavaScript----原生js封装事件绑定$on、事件触发$emit和事件移除$off

    事件分析:一对多,观察者模式
      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
    }
  • 相关阅读:
    Product of Array Except Self
    Sliding Window Maximum
    First Bad Version
    Perfect Squares
    IPsec Note
    BGP实验第9-10选路原则
    BGP选路第3条原则
    BGP选路原则第1条至第8条
    BGP选路原则笔记 Cyrus
    Lab Block hole of BGP
  • 原文地址:https://www.cnblogs.com/snowstorm22/p/10441472.html
Copyright © 2011-2022 走看看