jQuery的波模块是于复杂的,前面只有涉及了对事件目标的包装。即统一了片兼容性的题目。这首会综合下jQuery的全方位事件模块。后面会详细分析jQuery.event.add/jQuery.event.remove/jQuery.event.trigger。

 

尽管如此事件模块代码很不便读,但那个提供的API接口还是坏清楚的。如下

jQuery 1

 

1. 长事件(bind/one/live/delegate/hover/toggle)

  • bind 基本的丰富事件函数
  • one 添加仅实行同一次于的风波函数
  • live 事件代理(使用document代理)
  • delegate 事件代理(使用指定元素代理)
  • hover 模拟css的hover
  • toggle 显示/隐藏

bind/one/live 都是以其中的jQuery.event.add 来成功事件添加。

delegate 内部调用的凡live。

hover 内部采用mouseenter/mouseleave,而mouseenter/mouseleave又用bind。

toggle 内部以click,而click内部又调用的是bind。

jQuery 2

 

骨子里jQuery的一个each调用就叫jQuery对象及平添了24单增长事件的快方法

jQuery.each( ("blur focus focusin focusout load resize scroll unload click dblclick " +
    "mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " +
    "change select submit keydown keypress keyup error").split(" "), function( i, name ) {

    // Handle event binding
    jQuery.fn[ name ] = function( data, fn ) {
        if ( fn == null ) {
            fn = data;
            data = null;
        }

        return arguments.length > 0 ?
            this.bind( name, data, fn ) :
            this.trigger( name );
    };

    if ( jQuery.attrFn ) {
        jQuery.attrFn[ name ] = true;
    }
});

如下图

jQuery 3

 

难忘,bind调用的是jQuery.event.add,因此 jQuery.event.add
才是举jQuery添加事件模块的基本。以上所有的计都是当其上述构建的上层应用。如图

jQuery 4

 

2. 抹事件 (unbind/die/undelegate)

unbind
删除事件基础艺术。可以去一个指定handler,还得去除某项目事件的所有handler,甚至足以去挂于element上的整个轩然大波。其里面调用jQuery.event.remove。

die/undelegate 删除事件代理。 内部都使用unbind。

 

之所以, jQuery.event.remove
才是一切jQuery删除事件模块的核心。unbind/die/undelegate都是在那个上述构建的上层应用。如图

jQuery 5

 

3 触发事件(trigger/triggerHandler)

  • trigger 触发一个波(会冒泡)
  • triggerHandler 触发一个轩然大波(不会见冒泡)

 

trigger/triggerHandler
内部调用的且是jQuery.event.trigger,因此jQuery.event.trigger
才是举jQuery触发事件模块的核心。如图

jQuery 6

相关文章

网站地图xml地图