首 页
|
域名注册
|
虚拟主机
|
网站制作
|
网站案例
|
网站优化
|
网站推广
|
企业邮局
|
服务器租用
|
广告设计
首页
域名注册
虚拟主机
网站建设
企业邮局
网站优化
网站备案
服务器租用
其它服务
百度竞价排名
yahoo搜索
Google搜索
新浪搜索引擎
搜狐搜索引擎
网易搜索引擎
创新互联专业百度关键词优化,百度排名优化,百度快照优化,网站建设的互联网企业!
域名注册
中文域名
英文域名
通用网址
域名解析
域名转入\转出
虚拟主机
主机购买
管理主机
FTP上传
数据库管理
主机续费升级
网站建设
建站流程介绍
网站设计
网站改版
网站维护
网站推广
企业邮局
邮箱使用
管理邮箱
邮箱续费升级
全球邮局
网站优化
seo优化
seo技巧
收索引擎优化
关键词优化
网站备案
备案流程指南
修改备案
备案资料下载
备案小技巧
服务器租用
服务器租用
服务器托管
其它服务
400电话
在线客服
财务常见问题
会员常见问题
您现在的位置:
创新互联
>>
网站建设
>> 网站建设常见问题 >> jQuery基本事件代码优化
jQuery基本事件代码优化
作者:谭小姐 文章来源:网站制作设计部 点击数:1612 更新时间:2009-9-14
jQuery对事件系统的抽象与优化也是它的一大特色 。本文仅从事件系统入手,简要分析一下jQuery为什么提供mouseenter和mouseleave事件,它们与标准的mouseover、mouseout事件有什么区别 。
事件模型
说到事件,就要追溯到网景与微软的“浏览器大战”了。当时,事件模型还没有标准,两家公司的实现就是事实标准。网景在Navigator中实现了“事件捕获”的事件系统,而微软则在IE中实现了一个基本上相反的事件系统,叫做“事件冒泡”。这两种系统的区别在于当事件发生时,相关元素处理(响应)事件的优先权不同。
下面举例说明这两种事件机制的区别 。假设文档中有如下结构:
<div>
<span>
<a>...</a>
</span>
</div>
因为这三个元素是嵌套的,所以单击了a,实际上也就单击了span和div 。换句话说,这三个元素都应该有处理单击事件的机会 。在事件捕获机制下,处理这个单击事件的优先次序是:div > span > a;而在事件冒泡机制下,处理这个单击事件的优先次序则是:a > span > div 。
后来,W3C的规范要求浏览器同时支持捕获和冒泡机制,并允许开发人员选择把事件注册到哪个阶段 。于是就有了下面这个注册事件的标准方法
target.addEventListener(type, listener, useCapture Optional );
其中:
type:字符串,表示监听的事件类型
listener:监听器对象(JavaScript函数),在指定事件发生时可以收到通知
useCapture:布尔值,是否注册到捕获阶段
在实际应用开发中,为了确保与IE(因为它不支持捕获)兼容,useCapture一般都指定为false(默认值也是false)。换句话说,只把事件注册到冒泡阶段;对于上面那个简单的例子来说,响应顺序就是:a > span > div 。
冒泡的副作用
如前所述,IE的冒泡事件模型基本上成为了事实标准。但冒泡有一个副作用。
仍以前面的文档结构为例,假设它是界面中的一个菜单项,我们希望用户鼠标离开div时隐藏菜单。于是,我们给div注册了一个mouseout事件 。如果用户鼠标是从div离开的,那么一切正确 。而如果用户鼠标是从a或span离开的,问题就来了。因为由于事件冒泡,从这两个元素开始分派的mouseout事件都会传播到div,从而导致鼠标并没有离开div,菜单就提前隐藏了。
当然,冒泡的副作用不难避免 。比如,给div内部的每个元素都注册mouseout事件,并使用.stopPropagation()方法阻止事件进一步传播 。对于IE,就得将事件对象的cancelBubble属性设置为false,取消事件冒泡 。不过,这仍然回到自己处理浏览器不兼容性问题的老路上了 。
优化方案
为了避免冒泡的副作用,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里,可以使用mouseenter和mouseleave事件来避免事件冒泡的副作用。
上一篇文章:
SEO闲谈:百度最近虽安静,外链优化还需更广泛
下一篇文章:
jQuery实战开发表单验证与自动完成提示插件
分享到:
QQ空间
新浪微博
腾讯微博
人人网
开心网
百度搜藏
腾讯微博
网易微博
创新互联
|
网站建设
|
网站案例
|
域名注册
|
网站空间
|
jsp虚拟主机
|
优化排名
|
服务器租用
|
云主机
|
网站营销推广
|
数据库知识
|
域名转入\转出
电话:028-86922220 13518219792 公司地址:成都市太升南路288号锦天国际A幢1002号
支持信箱:service@cdxwcx.com 版权所有:创新互联-网站设计制作 蜀ICP备13010860号
创新互联成都专业网站设计制作:网页设计,成都网站制作,成都网站建设,jQuery代码优化,jQuery基本事件代码优化