设为首页
收藏本站
最新电影
您现在的位置: 首页=>后台技术=>脚本特效=>其他 订阅本栏目  
“模拟mouseenter和mouseleave”的前因后果,mouseover/mouseout区别
时间: 2010-12-06 13:07:42 阅读次数:3434


1. mouseenter和mouseleave何时被触发?
2. 与mouseover和mouseout的区别是什么?
3. 为什么要模拟?
4. 如何模拟?

一. mouseenter和mouseleave何时被触发我们来看下官方解释(mouseenter飞.飞Asp技术乐园mouseleave飞,飞Asp技术乐园):


// onmouseenter:Fires when the user moves the mouse pointer inside the boundaries of an object.即:当鼠标移入元素对象的边界之内时,激活该事件

// onmouseleave:Fires when the user moves the mouse pointer outside the boundaries of the object.即:当鼠标移出元素对象的边界之外时,激活该事件



二. 与mouseover和mouseout的区别官方站点在介绍mouseenter和mouseleave时,同时说明了与mouseover和mouseout的不同:


// onmouseenter vs onmouseoverUnlike the onmouseover event, the onmouseenter event does not bubble. In other words, the onmouseenter event does not fire when the user moves the mouse pointer over elements contained by the object, whereas onmouseover does fire.即:onmouseenter不会冒泡,onmouseover则会,由于这个差异,当鼠标在元素边界内移动时,不会激活onmouseenter(只在鼠标进入元素边界内时激活),但会激活onmouseover(当该元素包含子元素时)。

// onmouseleave vs onmouseout同上,由于存在冒泡的差异,导致了鼠标在元素边界内移动时,会激活onmouseout(当该元素包含子元素时),但不会激活onmouseleave。



三. 为什么要模拟mouseenter和mouseleave?

原因很简单:相对于mouseover和mouseout,mouseenter和mouseleave具有性能优势(不会反复触发),但只有IE支持它。。。

四. 如何模拟?

原理:监听目标元素的mouseover和mouseout事件,只当鼠标移入目标元素时,才执行回调函数,忽略子元素上激活的mouseover和mouseout事件。我们通过事件对象的relatedTarget属性,来判断鼠标是移入/移出目标元素,还是在目标元素内移动:
(1) 当mouseover被激活时,relatedTarget表示鼠标进入目标元素时,是从哪个元素离开的,我们可以对relatedTarget的值进行判断:如果值不是目标元素,也不是目标元素的子元素,就说明鼠标已移入目标元素;
(2) 当mouseout被激活时,relatedTarget表示鼠标离开目标元素时,进入了哪个元素,我们同样可以对relatedTarget的值进行判断:如果值不是目标元素,也不是目标元素的子元素,就说明鼠标已移出目标元素;

五. 实例

// HTML:
<ul id="J_List">
<li><a href="#">item1</a></li>
<li><a href="#">item2</a></li>
<li><a href="#">item3</a></li>
</ul>



<script type="text/javascript">
var Y = YAHOO.util,
Dom = Y.Dom,
Event = Y.Event;
// 获取所有的li
var oList = Dom.get('J_List');
Event.on(oList, 'mouseover', function(e) {
var rt = Event.getRelatedTarget(e),
curElem = this;
// 如果rt不是curElem且不是curElem的子元素, 则就是mouse enter的情况
if (rt !== curElem && !Dom.isAncestor(curElem, rt)) {
console.log('enter: ' + curElem.id);
}
});
Event.on(oList, 'mouseout', function(e) {
var rt = Event.getRelatedTarget(e),
curElem = this;
// 如果rt不是curElem且不是curElem的子元素, 则就是mouse leave的情况
if (rt !== curElem && !Dom.isAncestor(curElem, rt)) {
console.log('leave: ' + curElem.id);
}
});
</script>




站内搜索    

下一篇为非IE浏览器添加mouseenter,mouseleave事件

上一篇用键盘打开网页代码

本栏目最新 栏目最新列表
xhEditor v1.1.7 发布,国产开源XHTML在线编
收集的一些轻量级非常实用的前端开发小工具
javascript中cookie的设置,读取,删除
jquery插件:飞飞表情插件v1.0_[普通表情/魔
Jquery插件:textarea使用“autoresize”自
网站优化策划 栏目最新列表
增加网站外链的快速方法
网站上线前必做的30个检查
新的友情链接参考标准(没有google的PR情况
优化Google的AdSense广告的五个工具
王通讲SEO八大基础
站点最新 站点最新列表
微博推广的一些技巧
xhEditor v1.1.7 发布,
收集的一些轻量级非常实
50个新鲜兼容最新版本的
javascript中cookie的设
Excel中出现#VALUE!、#D
jquery插件:飞飞表情插件
十个使用HTML5开发的精彩
支持HTML5的浏览器有哪些
飞妮莫属:漫画:如何写出
历史最热10条信息  
MIME介绍 及 [1] [2] [3]
巧用Google和迅雷来下载
VIA Rhine II Fast Ethe
Transact SQL 常 [1] [2]
电脑常用端 [1] [2] [3]
十道羊皮卷 欣赏+mp3版+
Do you get a kick out
每日一句:A friend and
每日一句:Theres no tu
网站开发常用手册
相关文章
“模拟mouseenter和
为非IE浏览器添加mo
jquery的live绑定多
 
 width= 
伟哥博客 西安房产 123最新电影 三四六四