这两种自定义事件的绑定方式有什么区别?哪种好?

第一种方式,直接将自定义事件存放在__onfireEvents中

var __onfireEvents = {};function _bind(eventName, callback, is_one, context) {    
if (typeof eventName !== string_str || typeof callback !== function_str) {        
throw new Error('args: '+string_str+', '+function_str+'');
    }    if (! hasOwnKey(__onfireEvents, eventName)) {
        __onfireEvents[eventName] = {};
    }
    __onfireEvents[eventName][++__cnt] = [callback, is_one, context];    return [eventName, __cnt];
}function on(eventName, callback, context) {    return _bind(eventName, callback, 0, context);
}

第二种方式,同样是将自定义事件存储起来,不同之处是绑定在元素上,是否有必要?这里有什么优势吗?

$customSubMap = {};
subscribeEvent = function ( $collection, event_name, fn ) {
    $collection.on( event_name, fn );   

    if ( ! $customSubMap[ event_name ] ) {
        $customSubMap[ event_name ] = $collection;
    }    else {
        $customSubMap[ event_name ]
        = $customSubMap[ event_name ].add( $collection );
    }
};


汪汪一只猫
浏览 536回答 1
1回答
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

JavaScript