博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
读jQuery之十(事件模块概述)
阅读量:6153 次
发布时间:2019-06-21

本文共 1571 字,大约阅读时间需要 5 分钟。

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个添加事件的快捷方法

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://wcbfa.baihongyu.com/

你可能感兴趣的文章
Python异步IO --- 轻松管理10k+并发连接
查看>>
Oracle中drop user和drop user cascade的区别
查看>>
登记申请汇总
查看>>
Android Jni调用浅述
查看>>
CodeCombat森林关卡Python代码
查看>>
第一个应用程序HelloWorld
查看>>
(二)Spring Boot 起步入门(翻译自Spring Boot官方教程文档)1.5.9.RELEASE
查看>>
Java并发编程73道面试题及答案
查看>>
企业级负载平衡简介(转)
查看>>
Shell基础之-正则表达式
查看>>
JavaScript异步之Generator、async、await
查看>>
讲讲吸顶效果与react-sticky
查看>>
c++面向对象的一些问题1 0
查看>>
售前工程师的成长---一个老员工的经验之谈
查看>>
Get到的优秀博客网址
查看>>
老男孩教育每日一题-第107天-简述你对***的理解,常见的有哪几种?
查看>>
Python学习--time
查看>>
在OSCHINA上的第一篇博文,以后好好学习吧
查看>>
Spring常用注解
查看>>
linux:yum和apt-get的区别
查看>>