jQuery事件处理(七)
1、自定义事件(用户手动trigger的一般都是自定义事件)
trigger: function( event, data, elem, onlyHandlers ) {
var i, cur, tmp, bubbleType, ontype, handle, special,
// 如果没有传入elem(绑定到那个DOM元素上的事件),则默认为document
eventPath = [ elem || document ],
// core_hasOwn是hasOwnProperty的替代,检测event上是否有type属性,如果有就将其赋值给type,否则说明event就是type
type = core_hasOwn.call( event, "type" ) ? event.type : event,
// 事件的命名空间处理
namespaces = core_hasOwn.call( event, "namespace" ) ? event.namespace.split(".") : [];
cur = tmp = elem = elem || document;
// 如果元素时文本节点或者是注释则直接返回
if ( elem.nodeType === 3 || elem.nodeType === 8 ) {
return;
}
// 排除替代事件??
if ( rfocusMorph.test( type + jQuery.event.triggered ) ) {
return;
}
// 如果type中有.号,
if ( type.indexOf(".") >= 0 ) {
// 得到自定事件的所有命名空间
namespaces = type.split(".");
// 第一个是自定义事件的类型
type = namespaces.shift();
//
namespaces.sort();
}
// 如果type中没有冒号,则为type加上“on”
ontype = type.indexOf(":") < 0 && "on" + type;
// 看看有没有jQuery封装后的event对象的标记,如果没有则进行一下改造
event = event[ jQuery.expando ] ?
event :
new jQuery.Event( type, typeof event === "object" && event );
// 为event对象添加一些额外的属性
event.isTrigger = onlyHandlers ? 2 : 3;
event.namespace = namespaces.join(".");
event.namespace_re = event.namespace ?
new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ) :
null;
// 重置event的result属性
event.result = undefined;
// 如果event没有target属性,则将elem赋值给它
if ( !event.target ) {
event.target = elem;
}
// 将传入的data放到数组中,并将event放到数组的第二个元素位置
data = data == null ?
[ event ] :
jQuery.makeArray( data, [ event ] );
// 看看是不是特殊事件,如果是,用特殊事件的处理方式,并在返回false时返回。
special = jQuery.event.special[ type ] || {};
if ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) {
return;
}
// 如果不是onlyHandlers 并且特殊事件不需要冒泡,并且不是window
if ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) {
// 如果有替代事件类型,则使用替代事件类型
bubbleType = special.delegateType || type;
// 如果不是foucusin和foucusout事件
if ( !rfocusMorph.test( bubbleType + type ) ) {
// 则将当前指定为该元素的父元素
cur = cur.parentNode;
}
// 遍历自身及其所有祖先元素,因为自动义事件不会向上冒泡
for ( ; cur; cur = cur.parentNode ) {
// 将他们推入eventpath中。
eventPath.push( cur );
tmp = cur;
}
// 如果最后一个cur是document,则事件触发到window对象上,将window推入队列
if ( tmp === (elem.ownerDocument || document) ) {
eventPath.push( tmp.defaultView || tmp.parentWindow || window );
}
}
// 触发该元素上的所有事件处理函数
i = 0;
while ( (cur = eventPath[i++]) && !event.isPropagationStopped() ) {
event.type = i > 1 ?
bubbleType :
special.bindType || type;
// 拿到对应的event和handle
handle = ( data_priv.get( cur, "events" ) || {} )[ event.type ] && data_priv.get( cur, "handle" );
if ( handle ) {
// 如果有handle就触发
handle.apply( cur, data );
}
// 拿到原始的事件类型
handle = ontype && cur[ ontype ];
// 看是否需要阻止默认事件
if ( handle && jQuery.acceptData( cur ) && handle.apply && handle.apply( cur, data ) === false ) {
event.preventDefault();
}
}
// 事件类型可能变了,重新赋值
event.type = type;
// 如果不需要阻止默认事件
if ( !onlyHandlers && !event.isDefaultPrevented() ) {
if ( (!special._default || special._default.apply( eventPath.pop(), data ) === false) &&
jQuery.acceptData( elem ) ) {
如果存在原始类型,并且存在事件处理函数,并且不是window
if ( ontype && jQuery.isFunction( elem[ type ] ) && !jQuery.isWindow( elem ) ) {
// 元素上的事件赋值给临时变量
tmp = elem[ ontype ];
// 清空该元素上的原始事件
if ( tmp ) {
elem[ ontype ] = null;
}
// 防止再次触发
jQuery.event.triggered = type;
// 触发事件处理程序
elem[ type ]();
// 清除标记防止再次触发的标记
jQuery.event.triggered = undefined;
if ( tmp ) {
// 再把原始事件写回来
elem[ ontype ] = tmp;
}
}
}
}
// 返回最后一个事件处理程序的返回值
return event.result;
},
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 使用 ...
- 从零开始学 Web 之 jQuery(七)事件冒泡,事件参数对象,链式编程原理
大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...
- 02-老马jQuery教程-jQuery事件处理
1. 绑定简单事件 在DOM中DOM0级绑定事件的方式是直接给事件属性赋值,但是这样有个缺点就是每次指定的事件处理程序会把之前的覆盖掉. jQuery简单绑定事件的方式,可以让我绑定多个事件处理程序跟 ...
- jQuery事件处理(六)
1.通过一步步调试的的方法观察了一下存放到cache中的事件及其处理程序的数据格式: { events : { // 根据事件类型存放添加到该元素上的所有事件,下面以click为例 click : [ ...
- jQuery事件处理(五)
对原生js不熟悉看jQuery会困难很多.后续需要更多的关注下原生js jQuery封装之后的事件触发,其中一个分支(处理普通事件)是通过:elem.addEventListener( type, e ...
随机推荐
- ggplot2 提取stat计算出来的数据
使用ggplot2 绘图时,我们只需要提供原始数据就可以了,ggplot2 内置了许多的计算函数,来帮助我们计算对应的数值. 最典型的的,当使用geom_boxplot 绘制箱线图时,我们只提供原始数 ...
- 每天一个linux命令:pwd命令
Linux中用 pwd 命令来查看”当前工作目录“的完整路径. 简单得说,每当你在终端进行操作时,你都会有一个当前工作目录. 在不太确定当前位置时,就会使用pwd来判定当前目录在文件系统内的确切位置. ...
- java-信息安全(一)-BASE64,MD5,SHA,HMAC,RIPEMD算法
概述 信息安全基本概念: BASE64 编码格式 Base58 编码 MD5(Message Digest algorithm 5,信息摘要算法) SHA(Secure Hash Algorithm, ...
- springmvc接口ios网络请求
springmvc: application/json;charset=utf-8的ios网络请求: 后台使用 @RequestBody注解参数接收:
- 配置Tomcat监听80端口 配置Tomcat虚拟主机 Tomcat日志
配置Tomcat监听80端口 • vim /usr/local/tomcat/conf/server.xml Connector port=" protocol="HTTP/1.1 ...
- ping telnet ssh netstat
1.pingping命令工作在OSI参考模型的第三层-网络层.ping命令会发送一个数据包到目的主机,然后等待从目的主机接收回复数据包,当目的主机接收到这个数据包时,为源主机发送回复数据包,这个测试命 ...
- mysql中floor函数的作用是什么?
需求描述: 最近写mysql程序的时候,使用了floor函数,在此记录下该函数的作用 操作过程: 1.使用floor函数的测试 mysql> select floor(1.23),floor(- ...
- 模式(一)javascript设计模式
模式有三种:Architectural Pattern.Design Pattern.Coding Pattern,即:框架模式.设计模式.编程模式.本文主要讲解javascript中的设计模式,好的 ...
- while 1要小心
之前判断一个接口的返回,一定约定好了是返回retcode 1或者retcode 0,就用的这个判断,但是接口挂了的时候,一直返回未登录,找了很长时间为什么cpu一直消耗那么高. 使用wihle 1时候 ...
- SpringBoot------JPA连接数据库
步骤: 1.在pom.xml文件下添加相应依赖包 <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi=& ...