新闻中心
这篇文章主要介绍了jQuery基本事件代码优化的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
创新互联建站成都企业网站建设服务,提供成都网站设计、网站制作网站开发,网站定制,建网站,网站搭建,网站设计,响应式网站设计,网页设计师打造企业风格网站,提供周到的售前咨询和贴心的售后服务。欢迎咨询做网站需要多少钱:18980820575
事件模型
说到事件,就要追溯到网景与微软的“浏览器大战”了。当时,事件模型还没有标准,两家公司的实现就是事实标准。网景在Navigator中实现了“事件捕获”的事件系统,而微软则在IE中实现了一个基本上相反的事件系统,叫做“事件冒泡”。这两种系统的区别在于当事件发生时,相关元素处理(响应)事件的优先权不同。
下面举例说明这两种事件机制的区别 。假设文档中有如下结构:
后来,W3C的规范要求浏览器同时支持捕获和冒泡机制,并允许开发人员选择把事件注册到哪个阶段 。于是就有了下面这个注册事件的标准方法
target.addEventListener(type, listener, useCapture Optional );
listener:监听器对象(JavaScript函数),在指定事件发生时可以收到通知
如前所述,IE的冒泡事件模型基本上成为了事实标准。但冒泡有一个副作用。
为了避免冒泡的副作用,jQuery提供了mouseenter和mouseleave事件,就使用它们来代替mouseover和mouseout吧 。
下面这个摘自jQuery的内部函数withinElement,就是为mouseenter和mouseleave提供支持的 。翻译了一下注释,仅供大家参考 。
// 下面这个函数用于检测事件是否发生在另一个元素的内部 // 在 jQuery.event.special.mouseenter 和 mouseleave 处理程序中使用 var withinElement = function( event ) { // 检测 mouse(over|out) 是否还在相同的父元素内 var parent = event.relatedTarget; // 设置正确的事件类型 eventevent.type = event.data; // Firefox 有时候会把 relatedTarget 指定一个 XUL 元素 // 对于这种元素,无法访问其 parentNode 属性 try { // Chrome 也类似,虽然可以访问 parentNode 属性 // 但结果却是 null if ( parent && parent !== document && !parent.parentNode ) { return; } // 沿 DOM 树向上 while ( parent && parent !== this ) { parentparent = parent.parentNode; } if ( parent !== this ) { // 如果实际正好位于一个非子元素上面,那好,就处理事件 jQuery.event.handle.apply( this, arguments ); } // 假定已经离开了元素,因为很可能鼠标放在了一个XUL元素上 } catch(e) { } },
感谢你能够认真阅读完这篇文章,希望小编分享的“jQuery基本事件代码优化的示例分析”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!
分享标题:jQuery基本事件代码优化的示例分析
标题链接:http://jxjierui.cn/article/pisopo.html