zoukankan      html  css  js  c++  java
  • jQuery源码分析系列:事件模块概述

    jQuery的事件模块是较复杂的,前面仅仅提到了对事件对象的包装。即统一了一些兼容性的问题。这篇会综述下jQuery的整个事件模块。后面会详细分析jQuery.event.add/jQuery.event.remove/jQuery.event.trigger。


    虽然事件模块代码很难读,但其提供的API接口还是很清晰的。如下


    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的一个each调用就给jQuery对象上增加了24个添加事件的快捷方法

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    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;
        }
    });

    如下图


    记住,bind调用的是jQuery.event.add,因此 jQuery.event.add 才是整个jQuery添加事件模块的核心。以上所有的方法都是在其之上构建的上层应用。如图


    2 删除事件 (unbind/die/undelegate)

    unbind 删除事件基础方法。可以删除一个指定handler,还可以删除某类型事件的全部handler,甚至可以删除挂在element上的全部事件。其内部调用jQuery.event.remove。

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


    因此, jQuery.event.remove 才是整个jQuery删除事件模块的核心。unbind/die/undelegate都是在其之上构建的上层应用。如图


    3 触发事件(trigger/triggerHandler)

    trigger 触发一个事件(会冒泡)

    triggerHandler 触发一个事件(不会冒泡)


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

    原文路径:http://www.cnblogs.com/snandy/archive/2011/06/27/2085062.html
  • 相关阅读:
    String类之indexOf--->查找某字对应的位置
    5、文件过滤器
    String类之endsWith方法--->检测该字符串以xx为结尾
    for循环
    java-成员方法/变量、类方法/变量等区别
    4、File类之获取方法
    3、File类之创建、删除、重命名、判断方法
    2、创建File类对象
    Java 实现Redis客户端,服务端
    Phoenix踩坑填坑记录
  • 原文地址:https://www.cnblogs.com/colorstory/p/2617809.html
Copyright © 2011-2022 走看看