有没有做机械加工的网站,长泰网站建设,做微信公众号必备的网站,在企业网站建设的解决方案中jQuery的事件模块是较复杂的#xff0c;前面仅仅提到了对事件对象的包装。即统一了一些兼容性的问题。这篇会综述下jQuery的整个事件模块。后面会详细分析jQuery.event.add/jQuery.event.remove/jQuery.event.trigger。 虽然事件模块代码很难读#xff0c;但其提供的API接口还… 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 转载于:https://www.cnblogs.com/colorstory/archive/2013/04/11/2617809.html