跨浏览器的事件对象

虽然DOM和IE中的event对象不同,但基于他们之间相似依旧可以拿出跨浏览器方案来。

var EventUtil = {
      addHandler: function(event){
              return event ? event : window.event;
       },
       getTarget: function(event){
            return event.target || event.srcElement;
       },
      preventDefault: function(event){
            if(event.preventDefault){
                    event.preventDefault();
            } else {
                    event.returnValue = false;
            }
      },
      removeHandler: function(ele,type,handler){
      },
      stopPropagation: function(event){
            if(event.stopPropagation){
                  event.stopPropagation();
            } else {
                  event.cancelBubble = true;
            }
      }
};

以上代码显示,我们为EventUtil添加了4个新的方法。第一个是getEvent(),它返回的是event对象的引用。考虑到IE重实践对象的位置不同,可以使用这个方法来取得event对象,而不必担心指定事件处理程序的方式。在使用这个方法时,必须假设有一个事件对象传入到时间处理程序中,而且把该变量传给这个方法,如下所示。

btn.onclick = function(event){
      event = EventUtil.getEvent(event);
}

在兼容DOM的浏览器中。event变量只是简单的传入和传回。而在IE中event参数是未定义的(undefined),因此就会返回window.event。将这一行代码添加到事件处理程序的开头,就可以确保随时都能使用event对象,而不必担心用户使用的是什么浏览器。
第二个方法时getTarget(),他返回的是事件目标。在这个方法内部,会检测event对象的target属性,如果存在返回该属性的值,否则,返回srcElement属性的值。可以像下面这样使用这个方法。

btn.onclick = function(event){
      event = EventUtil.getEvent(event);
      var target = EventUtil.getTarget(event);
}

第三个方法是preventDefault(),用于取消事件的默认行为。在传入event对象后,这个方法会检查是否存在preventDefault()方法,如果存在调用该方法。如果preventDefault()方法不存在,则将returnValue设置为false。下面是这个方法的例子。

var link = document.getElementById("myLink");
link.onclick = function(event){
      event = EventUtil.getEvent(event);
       EventUtil.preventDefault(event);
};

以上代码可以确保在所有浏览器中单击该链接都不会打开另一个页面。首先,使用EventUtil.getEvent()取得event对象,然后将其传入EventUtil.preventDefault()以取消默认行为。

第四个方法是stopPropagation(),其实现方式类似。首先尝试使用DOM方法阻止事件流,否则就是用cancelBubble属性。下面看一个例子。

var btn = document.getElementById("myBtn");
btn.onclick = function(event){
    alert("Click");
    event = EventUtil.getEvent(event);
    EventUtil.stopPropagation(event);
};
document.body.onclick = function(event){
    alert("Body Click");
};

再次,首先使用EventUtil.getEvent()取得了event对象,然后将其传入到EventUtil.stopPropagation()。别忘了由于IE不支持时间不活,因此这个方法在跨浏览器的情况下,也只能用来组织事件冒泡。

你可能感兴趣的:(跨浏览器的事件对象)