jQuery学习-事件之绑定事件(四)
今天我们来学习jQuery.Event对象。jQuery为了添加自己的处理机制,及可以传递用户自定义数据,于是Event对象就出世了。
1 jQuery.Event = function( src, props ) {
2 //instanceof 用于判断一个变量是否某个对象的实例
3 if ( !(this instanceof jQuery.Event) ) {
4 return new jQuery.Event( src, props );
5 }
6
7 // Event object
8 if ( src && src.type ) {
9 /*
10 如果是event对象
11 * */
12 this.originalEvent = src;//将原生的event对象存于Event中
13 this.type = src.type;//事件类型
14
15 // Events bubbling up the document may have been marked as prevented
16 // by a handler lower down the tree; reflect the correct value.
17 /*
18 修正isDefaultPrevented方法
19 * */
20 this.isDefaultPrevented = src.defaultPrevented ||
21 src.defaultPrevented === undefined &&
22 // Support: IE < 9, Android < 4.0
23 src.returnValue === false ?
24 returnTrue :
25 returnFalse;
26
27 // Event type
28 } else {
29 //如果event是事件名称
30 this.type = src;
31 }
32
33 // Put explicitly provided properties onto the event object
34 //添加自定义属性
35 if ( props ) {
36 jQuery.extend( this, props );
37 }
38
39 // Create a timestamp if incoming event doesn't have one
40 this.timeStamp = src && src.timeStamp || jQuery.now();//添加时间戳
41
42 // Mark it as fixed
43 this[ jQuery.expando ] = true;//标识event已被处理过
44 };
45
46 jQuery.Event.prototype = {
47 isDefaultPrevented: returnFalse,
48 isPropagationStopped: returnFalse,
49 isImmediatePropagationStopped: returnFalse,
50
51 preventDefault: function() {
52 /*
53 修正【阻止默认事件】
54 * */
55 var e = this.originalEvent;//取出原生evnet
56
57 this.isDefaultPrevented = returnTrue;
58 if ( !e ) {
59 return;
60 }
61
62 // If preventDefault exists, run it on the original event
63 if ( e.preventDefault ) {
64 e.preventDefault();
65
66 // Support: IE
67 // Otherwise set the returnValue property of the original event to false
68 } else {
69 e.returnValue = false;
70 }
71 },
72 stopPropagation: function() {
73 /*
74 修正【停止冒泡】
75 * */
76 var e = this.originalEvent;//取出原生evnet
77
78 this.isPropagationStopped = returnTrue;
79 if ( !e ) {
80 return;
81 }
82 // If stopPropagation exists, run it on the original event
83 if ( e.stopPropagation ) {
84 e.stopPropagation();
85 }
86
87 // Support: IE
88 // Set the cancelBubble property of the original event to true
89 e.cancelBubble = true;
90 },
91 stopImmediatePropagation: function() {
92 /*
93 修正【stopImmdiatePropagation】
94 stopImmediatePropagation 的功能比stopPropagation 多一些,
95 除了可以阻止事件冒泡之外,还可以把这个元素绑定的同类型事件也阻止了。
96 * */
97 var e = this.originalEvent;
98
99 this.isImmediatePropagationStopped = returnTrue;
if ( e && e.stopImmediatePropagation ) {
e.stopImmediatePropagation();
}
this.stopPropagation();
}
107 };
Event方法主要是对兼容性做了处理看注释应该就明白了!
jQuery学习-事件之绑定事件(四)的更多相关文章
- jQuery学习-事件之绑定事件(三)
在上一篇<jQuery学习-事件之绑定事件(二)>我们了解了jQuery的dispatch方法,今天我们来学习下handlers 方法: handlers: function( event ...
- jQuery学习-事件之绑定事件(二)
在上一篇<jQuery学习-事件之绑定事件(一)>我们了解了jQuery的add方法,今天我们来学习下dispatch方法: dispatch: function( event ) { ...
- jQuery学习-事件之绑定事件(一)
我们都知道jQuery的事件其思想来源于Dean Edwards的addEvent,通过源码我们知道jQuery在为元素绑定事件时,每种类型的事件(click,blur)时只绑定了一次对应类型的事件处 ...
- jQuery如何给body绑定事件?
jQuery如何给body绑定事件? 代码如下: $(document).bind("resize", function () { alert("php-note.com ...
- JQuery在循环中绑定事件的问题详解
JQuery在循环中绑定事件的问题详解 有个页面上需要N个DOM,每个DOM里面的元素ID都要以数字结尾,比如说 ? 1 2 3 <input type="text" nam ...
- jQuery学习小结1-CSS操作+事件
一.DOM对象和jQuery 对象互换 1.jQuery对象 就是通过jQuery包装DOM对象后产生的对象.jQuery对象是jQuery独有的,其可以使用jQuery里的方法.比如: $(&quo ...
- jquery html 动态添加元素绑定事件
由于实际的需要,有时需要往网页中动态的插入HTML内容,并在插入的节点中绑定事件处理函数.我们知道,用Javascript向HTML文档中 插入内容,有两种方法, 一种是在写HTML代码写入JS,然后 ...
- jQuery相关方法7----各种事件和绑定事件
一.jQuery事件 1.鼠标事件 click与dbclick事件 click事件其实是由mousedown与mouseup 2个动作构成,所以点击的动作只有在松手后才触发 $ele.click(): ...
- jquery学习笔记(三):事件和应用
内容来自[汇智网]jquery学习课程 3.1 页面加载事件 在jQuery中页面加载事件是ready().ready()事件类似于就JavaScript中的onLoad()事件,但前者只要页面的DO ...
- [jquery]高级篇--js绑定事件
参考: http://www.cnblogs.com/leejersey/p/3545372.html jQuery on()方法是官方推荐的绑定事件的一个方法.$(selector).on(eve ...
随机推荐
- Spring MVC一个方法适用多种调用方式
web.xml spring-mvc.xml <mvc:annotation-driven /> <context:component-scan base-package=" ...
- iOS Dev (21) 用 AVPlayer 播放一个本地音频文件
iOS Dev (21) 用 AVPlayer 播放一个本地音频文件 作者:CSDN 大锐哥 博客:http://blog.csdn.net/prevention 前言 这篇文章与上一篇极其相似,要注 ...
- php 函数之 )_each()list()implode()explode()in_array()
<?php /* implode() 把数组组合成字符串 explode() 把字符串分割成数组 in_array() 检测内容是否在数组中 each()把数组元素拆分成新的数组 list() ...
- python socket 编程之三:长连接、短连接以及心跳
长连接:开启一个socket连接,收发完数据后,不立刻关闭连接,可以多次收发数据包. 短连接:开启一个socket连接,收发完数据后,立刻关闭连接. 心跳:长连接在没有数据通信时,定时发送数据包(心跳 ...
- ICE-3.5.1-错误记录
windwos上QT5使用ICE中遇到的一个小bug: error: C3083: “Stm”:“::”左侧的符号必须是一种类型error: C2039: “upCast”: 不是“IceProxy” ...
- 在Azure Cloud Service中部署Java Web App(2)
接上文. 9.在进行发布之前,需要对我们的订阅做一些设置,因为默认情况下,Azure的service end指向的是Azure global的站点,如果我们要将服务发布在Azure的中国站点,需要做下 ...
- Linux文件解压缩详解
tar命令 我们知道在Windows下最常见的压缩文件就只有两种,一是,zip,另一个是.rar.可是Linux就不同了,它有.gz..tar.gz.tgz.bz2..Z..tar等众多的压缩文件名, ...
- delphi 操作 TWebBrowser 实现自动填表(JQuery脚本与 OleVariant 方法)
版本:DELPHI XE8 操作交通银行信用卡申请表单(2016-03-23),网址如下: https://creditcardapp.bankcomm.com/applynew/front/appl ...
- User has no SELECT privilege on V$SESSION
今天是2013-09-20,最近心情一直很差,但是也不能不学习啊,无论怎么样,自己学到 的东西永远都是自己的.加油! 使用dbms_xplan.display_cursor function ...
- paip.svn使用最佳实践
paip.svn使用最佳实践 作者Attilax , EMAIL:1466519819@qq.com 来源:attilax的专栏 地址:http://blog.csdn.net/attilax 1 ...