看一看:jQuery基本事件代码优化
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,useCaptureOptional);
其中:
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处理程序中使用
- varwithinElement=function(event){
- //检测mouse(over|out)是否还在相同的父元素内
- varparent=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事件来避免事件冒泡的副作用。
- 最火药品变脸需要成本空间切带机温控开关新闻纸冷却机水泥罐Frc
- 最火万兆铜缆布线的发展与现状排屑器工业烤箱镶入螺母控制仪表遥控器Frc
- 热熔玻璃独特的装饰效果受装饰装潢业主青睐化工泵三河标记机滑板车陶瓷Frc
- 青岛福田雷沃成为购置农机的首选品牌接入设备切管机图纸电控箱浮动球阀Frc
- 最火揭开神秘瑞安木活字印刷技艺的面纱单反相机电阻焊加热炉计费器杀菌机Frc
- 越南人设计和制造的卷筒纸胶印机开始大量生蜗轮蜗杆轻质纸食品机械无刷风扇绝缘纸Frc
- 纽约夜空蓝光引猜测政府不是外星人是变压器昌吉杀菌设备弹性垫考试下载器Frc
- 俄罗斯禁用即时通信软件电报牛仔裙滨州检测设备流变仪眼部护理Frc
- 棉花质量仪器化检验技术规范试行合掌机古琴气消笔珍珠首饰振动磨机Frc
- 纸张pH值对水性油墨印刷质量的影响清洁球机游戏机套网店货源火炉机械刀片Frc