loading请求处理中...

jQuery插件开发优化方案 避免IE冒泡事件副作用

2021-12-01 02:01:36 阅读 12049次 标签: 作者: anyi

   jQuery是目前非常流行的Javascript库之一,随着jQuery应用程序的逐渐增多,插件开发就是其中一种,其性能优化问题是程序员们不可忽视的,我们知道在jQuery中最快的选择器是ID选择器,因为它直接来自于JavaScript的getElementById()方法。

jQuery插件开发优化方案

    jQuery插件开发对事件系统的抽象与优化也是它的一大特色。下面从事件系统入手,简要分析一下jQuery为什么提供mouseenter和mouseleave事件,它们与标准的mouseover、mouseout事件有什么区别。
    事件模型
    说到事件,就要追溯到网景与微软的“浏览器大战”了。当时,事件模型还没有标准,两家公司的实现就是事实标准。网景在Navigator中实现了“事件捕获”的事件系统,而微软则在IE中实现了一个基本上相反的事件系统,叫做“事件冒泡”。这两种系统的区别在于当事件发生时,相关元素处理(响应)事件的优先权不同。
    冒泡的副作用
    IE的冒泡事件模型基本上成为了事实标准。但冒泡有一个副作用。
    仍以前面的文档结构为例,假设它是界面中的一个菜单项,我们希望用户鼠标离开div时隐藏菜单。于是,我们给div注册了一个mouseout事件 。如果用户鼠标是从div离开的,那么一切正确  。而如果用户鼠标是从a或span离开的,问题就来了。因为由于事件冒泡,从这两个元素开始分派的mouseout事件都会传播到div,从而导致鼠标并没有离开div,菜单就提前隐藏了。
    当然,冒泡的副作用不难避免 。比如,给div内部的每个元素都注册mouseout事件,并使用.stopPropagation()方法阻止事件进一步传播  。对于IE,就得将事件对象的cancelBubble属性设置为false,取消事件冒泡  。不过,这仍然回到自己处理浏览器不兼容性问题的老路上了  。
    优化方案
    为了避免冒泡的副作用,jQuery提供了mouseenter和mouseleave事件,就使用它们来代替mouseover和mouseout吧。
    因此,在jQuery里,可以使用mouseenter和mouseleave事件来避免事件冒泡的副作用。这样jQuery插件开发就得到了相应的优化。
(一品威客 anyi)

公司推荐

成为一品威客服务商,百万订单等您来有奖注册中

留言( 展开评论

快速发任务

价格是多少?怎样找到合适的人才?

官方顾问免费为您解答