今天我们来学习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学习-事件之绑定事件(四)的更多相关文章

  1. jQuery学习-事件之绑定事件(三)

    在上一篇<jQuery学习-事件之绑定事件(二)>我们了解了jQuery的dispatch方法,今天我们来学习下handlers 方法: handlers: function( event ...

  2. jQuery学习-事件之绑定事件(二)

    在上一篇<jQuery学习-事件之绑定事件(一)>我们了解了jQuery的add方法,今天我们来学习下dispatch方法: dispatch: function( event ) {   ...

  3. jQuery学习-事件之绑定事件(一)

    我们都知道jQuery的事件其思想来源于Dean Edwards的addEvent,通过源码我们知道jQuery在为元素绑定事件时,每种类型的事件(click,blur)时只绑定了一次对应类型的事件处 ...

  4. jQuery如何给body绑定事件?

    jQuery如何给body绑定事件? 代码如下: $(document).bind("resize", function () { alert("php-note.com ...

  5. JQuery在循环中绑定事件的问题详解

    JQuery在循环中绑定事件的问题详解 有个页面上需要N个DOM,每个DOM里面的元素ID都要以数字结尾,比如说 ? 1 2 3 <input type="text" nam ...

  6. jQuery学习小结1-CSS操作+事件

    一.DOM对象和jQuery 对象互换 1.jQuery对象 就是通过jQuery包装DOM对象后产生的对象.jQuery对象是jQuery独有的,其可以使用jQuery里的方法.比如: $(&quo ...

  7. jquery html 动态添加元素绑定事件

    由于实际的需要,有时需要往网页中动态的插入HTML内容,并在插入的节点中绑定事件处理函数.我们知道,用Javascript向HTML文档中 插入内容,有两种方法, 一种是在写HTML代码写入JS,然后 ...

  8. jQuery相关方法7----各种事件和绑定事件

    一.jQuery事件 1.鼠标事件 click与dbclick事件 click事件其实是由mousedown与mouseup 2个动作构成,所以点击的动作只有在松手后才触发 $ele.click(): ...

  9. jquery学习笔记(三):事件和应用

    内容来自[汇智网]jquery学习课程 3.1 页面加载事件 在jQuery中页面加载事件是ready().ready()事件类似于就JavaScript中的onLoad()事件,但前者只要页面的DO ...

  10. [jquery]高级篇--js绑定事件

    参考:  http://www.cnblogs.com/leejersey/p/3545372.html jQuery on()方法是官方推荐的绑定事件的一个方法.$(selector).on(eve ...

随机推荐

  1. 【Android类型SDK测试(一)】认识Android类型的 SDK

    (一)SDK是个什么东东 接触软件相关行业的同学都应该知道,SDK(即 Software Development Kit),软件开发包.其作用就是为开发某些软件提供一些便利的东西,包括工具 集合,文档 ...

  2. oracle使用还原段的目的和还原数据的管理方法及还原段的类型

    一.引入还原段主要有3个目的: 1.事务回滚:主要是针对rollback语句起作用 2.事务恢复:非正常关闭数据库即非保留事务级关闭数据库(abort.immediate)或者数据库instance崩 ...

  3. 项目 Web 的 NuGet 程序包还原失败: 找不到“1.0.0”版本的程序包“Microsoft.Net.Compilers”。。 0

    项目   Web 的 NuGet 程序包还原失败: 找不到“1.0.0”版本的程序包“Microsoft.Net.Compilers”.. 0 使用vs的NutGet包管理器时,另一台电脑从svn下载 ...

  4. Oracle EBS-SQL (PO-14):检查报价单与成本对比.sql

    select distinct         msi.segment1                                               项目        ,msi.de ...

  5. jquery 事件委托三种事件绑定方式.bind(),.live(),.delegate()

    http://www.ituring.com.cn/article/467# http://www.cnblogs.com/lvdabao/archive/2013/08/30/3290603.htm ...

  6. PHP实现好友生日邮件提醒

    我有一个想法是这样的,希望每天知道今天是我哪位好友的生日? 当然,我得首先保存我所有好友的生日信息 实现:在新浪申请免费服务器,并申请Mysql应用,然后建一张表保存好友的信息 我想,我已经完成第一步 ...

  7. poj 1088 滑雪_记忆化搜索

    题意:略 直接用记忆化搜索就行了 #include<cstdio> #include<iostream> using namespace std; int n,m; int m ...

  8. Ubuntu12.04 Jdk1.7 Tomct7.0部署配置

    jdk1.7 下载 http://download.oracle.com/otn-pub/java/jdk/7u67-b01/jdk-7u67-linux-x64.tar.gz?AuthParam=1 ...

  9. linux C之access函数 (20

    http://blog.sina.com.cn/s/blog_6a1837e90100uh5d.html linux C之access函数 (20access():判断是否具有存取文件的权限 相关函数 ...

  10. 卓尼斯ZT-180评測

    卓尼斯ZT-180评測    ——正在出差途中,用10”上网本发帖,没有拍照,且写得冲忙,不妥之处见谅. 一.採购 1.因外出旅游,不想带那台14"笔记本,所以想买一台平板电脑.当时,选择的 ...