在发生mouseover与mouseout事件时,还会涉及更多元素。这两个事件都会涉及把鼠标指针从一个元素的边界之内移到另一个元素的边界之内。对mouseover事件而言,事件主目标是获取光标元素,而相关元素就是那个失去光标的元素。类似的,对于mouseout事件,主目标是失去光标的元素,而相关元素是获得光标的元素。
DOM通过event对象的relatedTraget属性提供了相关元素的信息。这个属性只对于mouseover和mouseout事件才包含值;对于其他事件,它的属性值就为null。IE不支持relatedTarget属性,但是提供了保存同样信息的不同属性。在mouseover事件触发时,IE的fromElement属性中保存了相关元素;当mouseout事件触发时。IE的toElement属性中保存着相关属性值。具体实例如下:
//事件 移入移出
function addEvent(obj,type,fn){
if(obj.addEventListener){
obj.addEventListener(type,fn,false);
}else if(obj.attachEvent){
obj.attachEvent('on'+type,fn);
}
}
function removeEvent(obj,type,fn){
if(obj.removeEventListener){
obj.removeEventListener(type,fn,false);
}else if(obj.detachEvent){
obj.detachEvent('on'+type,fn);
}
}
addEvent(window,'load',function(){
var box=document.getElementById('box');
addEvent(box,'mouseover',function(evt){
alert(getTarget(evt));
});
});
function getTarget(evt){
var e=evt||window.event;
if(e.srcElement){//IE
if(e.type=='mouseover'){
return e.fromElement.tagName;
}else if(e.type=='mouseout'){
return e.toElement.tagName;
}
}else if(e.relatedTarget){//W3C
return e.relatedTarget;
}
}