jQuery事件处理
浏览器的事件模型
DOM第0级事件模型
- Event实例
他的属性提供了关于当前正被处理的已触发事件的大量信息。这包括一些细节,比如在哪个元素上触发的事件、鼠标事件的坐标以及键盘事件中单击了哪个键。
 - 事件冒泡
 
当触发 dom 树中一个元素上的事件时,事件模型会检查这个元素是否已经创建了特定的事件处理器。如果是,就会调用已创建的事件处理器。然后,事件模型会检查目标元素的父元素,看其是否已经为此事件类型创建了处理器。如果是,就调用已创建的处理器,之后检查它的父元素,以及父元素的父元素,以此类推,直到 dom 树的顶部。
DOM第2级事件模型
IE事件模型
jQuery事件模型
使用jQuery绑定事件处理器
<html>
<head>
<title>jQuery Events Example</title>
<script type="text/javascript" src="../scripts/jquery-1.7.1.js"></script>
<script type="text/javascript">
$(function () {
$('#example')
.bind('click', function (event) {
alert('BOOM once!');
})
.bind('click', function (event) {
alert('BOOM twice!');
})
.bind('click', function (event) {
alert('BOOM three times!');
});
});
</script>
</head> <body>
<img id="example" src="example.jpg" />
</body>
</html>
bind(eventType, data, handler); bind(eventMap)
可以为事件名称添加以圆点分隔的后缀来指定命名空间,以批量操作事件处理器。
可以通过单个bind()方法来为一个元素绑定多个事件。
$('.whatever').bind({
    click:function(event){/* handle */},
    mouseenter: function (event) {/* handle */ },
    mouseleave: function (event) {/* handle */ }
})
特定的事件绑定:
blur change click dblclick error focus focusin focusout keydown keypress keyup load mousedown mouseenter mouseleave mousemove mouseout mouseover mouseup ready resize scroll select submit unload
当使用这些便捷方法时,event.data值是只读的。他们有一个参数 listener 函数,表示事件处理器。
focusin focusout
one(eventType, data, listener)
删除事件处理器
unbind(eventType, listener); unbind(event)
删除特定的事件处理器
删除命名空间中的所有事件处理器
$('*').unbind('.fred')
Event实例
独立于浏览器的jQuery.Event属性和方法
| 名称 | 描述 | 
| altKey | |
| ctrlKey | |
| currentTarget | |
| data | |
| metaKey | |
| pageX | |
| pageY | |
| relatedTarget | |
| screenX | |
| screenY | |
| shiftKey | |
| result | |
| target | |
| timestamp | |
| type | |
| which | |
| preventDefault() | |
| stopPropagation() | |
| stopImmediatePropagation() | |
| isPropagationStopped() | |
| isImmediatePropagationStopped() | 
预先管理事件处理器(deprecated)
- 创建live事件处理
live(eventType, data, listener)
 - 删除live事件处理
die(eventType, listener)
 
触发事件处理器
trigger(eventType, data)
triggerHandler(eventType, data)
触发的便捷方法
blur() change() click() dblclick() error() focus() focusin() focusout() keydown() keypress() keyup() load() mousedown() mouseenter() mouseleave() mousemove() mouseout() mouseover() mouseup() resize() scroll() select() submit() unload()
其他事件相关的方法
- 起切换作用的监听器
toggle(listener1, listener2, ...)
 - 在元素上悬停鼠标
hover(enterHandler, leaveHandler); hover(handler)
 
充分利用(更多的)事件
过滤大的数据集合
通过模板复制创建元素
建立主体标记
添加新的过滤器
添加限定控件
删除不需要的过滤器和其他任务
总是有改进的余地
jQuery事件处理的更多相关文章
- [DOM Event Learning] Section 3 jQuery事件处理基础 on(), off()和one()方法使用
		
[DOM Event Learning] Section 3 jQuery事件处理基础 on(),off()和one()方法使用 jQuery提供了简单的方法来向选择器(对应页面上的元素)绑定事件 ...
 - jQuery事件处理了解一下
		
>>> JQuery 事件处理 一.事件绑定方式 1.事件绑定的快捷方式: 缺点:绑定的事件,无法取消 $("button:eq(0)").dblclick(fu ...
 - jQuery事件处理(四)
		
看了几天,决定整理一下jQuery事件处理的整体设计思路 1.通过add方法给选中的元素注册事件处理程序(通过缓存系统将事件储存到cache,而不是绑定到元素上) a.在存储之前,会为事件处理程序增加 ...
 - Unit02: jQuery事件处理 、 jQuery动画
		
Unit02: jQuery事件处理 . jQuery动画 jQuery实现购物车案例 <!DOCTYPE html> <html> <head> <titl ...
 - JQuery事件处理的注意事项
		
1.jQuery 名称冲突 jQuery 使用 $ 符号作为 jQuery 的简介方式. 某些其他 JavaScript 库中的函数(比如 Prototype)同样使用 $ 符号. jQuery 使用 ...
 - 02-老马jQuery教程-jQuery事件处理
		
1. 绑定简单事件 在DOM中DOM0级绑定事件的方式是直接给事件属性赋值,但是这样有个缺点就是每次指定的事件处理程序会把之前的覆盖掉. jQuery简单绑定事件的方式,可以让我绑定多个事件处理程序跟 ...
 - jQuery事件处理(七)
		
1.自定义事件(用户手动trigger的一般都是自定义事件) trigger: function( event, data, elem, onlyHandlers ) { var i, cur, tm ...
 - jQuery事件处理(六)
		
1.通过一步步调试的的方法观察了一下存放到cache中的事件及其处理程序的数据格式: { events : { // 根据事件类型存放添加到该元素上的所有事件,下面以click为例 click : [ ...
 - jQuery事件处理(五)
		
对原生js不熟悉看jQuery会困难很多.后续需要更多的关注下原生js jQuery封装之后的事件触发,其中一个分支(处理普通事件)是通过:elem.addEventListener( type, e ...
 - jQuery事件处理(一)
		
1.jQuery事件绑定的用法: $( "elem" ).on( events, [selector], [data], handler ); events:事件名称,可以是自定义 ...
 
随机推荐
- subltime快捷键
			
subltime 是一款快速开发各种文档的软件,本文主要介绍使用编写HTML,文章末尾提供绿色版安装包下载工具 A快捷键说明 Ctrl+Shift+P:打开命令面板Ctrl+P:搜索项目中的文件Ctr ...
 - drawRect:和layoutSubview的区别
			
关于这两个方法的区别 还是有点意思的. UIView的setNeedsDisplay和setNeedsLayout方法.首先两个方法都是异步执行的.setNeedsDisplay会调用自动调用draw ...
 - 洛谷P4027 [NOI2007]货币兑换(dp 斜率优化 cdq 二分)
			
题意 题目链接 Sol 解题的关键是看到题目里的提示... 设\(f[i]\)表示到第\(i\)天所持有软妹币的最大数量,显然答案为\(max_{i = 1}^n f[i]\) 转移为\(f_i = ...
 - JavaScript之DOM操作(一)
			
这篇文章写于2017-3-19,所有例子基于Chrome 56.0.X.如果时间太久,请自行查阅MDN等获取最新规范内容. 1.节点类型 从MDN上获取的最新情况 一共12种节点类型,分别由12个数值 ...
 - 润乾V4的最小化部署方式
			
 在接触到的很多项目实际应用中,部署润乾V4都是使用润乾V4设计器自带的WEB发布向导,直接生成webRoot目录,然后将该目录下的所有文件COPY到项目目录下,然后修改web.xml文件和rep ...
 - Date()对象的设置与解析
			
怎么获取当前时间? 怎么给Date对象设置特定时间? 将Date对象解析为毫秒数? 将Date对象解析为日月年?获取小时/分钟/秒? 直接new Date()新建对象,可以获取当前时间的Date对象: ...
 - 【翻译&转载】shader的导数函数介绍
			
原文链接:http://www.aclockworkberry.com/shader-derivative-functions/ 他人的翻译:http://blog.sina.com.cn/s/blo ...
 - Angular-学习。
			
今天刚学了点关于Angular的知识,就迫不及待的想跟大家来分享. 1.angular.extend ( )方法可以把一个或多个对象中的方法和属性扩展到一个目的对象中. <script typ ...
 - 32位Windows7 利用多余的不能识别的电脑内存 RAMDISK5.5教程
			
32位Windows7 利用多余的不能识别的电脑内存 RAMDISK5.5教程 环境:Windows7 32位 Ultimate 内存8GB 只能识别2.95GB内存 ramdisk5.5只适用于Wi ...
 - Oracle EBS 获取完全的值集信息
			
SELECT fvs1.flex_value_set_name, fvs1.description, decode(upper(fvs1.longlist_flag), 'N', '值列表', 'Y' ...