标签:
有一个DIV元素,其内部SPAN元素, 为了实现一些特殊的效果,我需要利用DIV元素的onmouseover和onmouseout事件,测试时就会发现如下的状况:if(this.contains(event.fromElement)){return;}
同样在onmouseout调用的方法中也加入如下判断,结果为假时再执行方法体:
if(this.contains(event.toElement)){return;}
下面来解释一下上面两行代码的含义:在IE中,所有的HTML元素都有一个contains方法,它的作用是判断当前元素内部是否包含指定的元素。我们利用这个方法来判断外层元素的事件是不是因为内部元素而被触发,如果内部元素导致了不需要的事件被触发,那我们就忽略这个事件。
event.fromElement指向触发onmouseover和onmouseout事件时鼠标离开的元素;event.toElement指向触发onmouseover和onmouseout事件时鼠标进入的元素。
那么上面两行代码的含义就分别是:但问题又来了,非IE的浏览器并不支持contains函数,不过既然我们已经知道了contains函数的作用,就可以自行添加如下的代码来为非IE浏览器增加contains支持:
if(typeof(HTMLElement) != "undefined") { HTMLElement.prototype.contains = function(obj) { while(obj != null && typeof(obj.tagName) != "undefind") { if(obj == this) return true; Obj = obj.parentNode; } return false; }; }
标签:
原文地址:http://my.oschina.net/153/blog/469076