js跨浏览器的事件侦听器和事件对象的使用方法

前端之家收集整理的这篇文章主要介绍了js跨浏览器的事件侦听器和事件对象的使用方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

本文特意为跨浏览器实现添加事件侦听器和跨浏览器事件对象的使用方法做了下总结,并把这些方法打包,欢迎大家学习。 打包的一个

EventUtil对象

添加侦听事件 addEventListener:function (element,type,handler) { // IE9+、Firefox、Safari、chrome和Opera if(element.addEventListener) { element.addEventListener(type,handler,false); } // IE8- else if(element.attachEvent) { element.attachEvent("on" + type,handler); } },// 移除侦听事件 removeEventListener:function (element,handler) { // IE9+、Firefox、Safari、chrome和Opera if(element.addEventListener) { element.removeEventListener(type,false); } // IE8- else if(element.attachEvent) { element.detachEvent("on" + type,// 获取事件对象 getEvent:function(event) { if(typeof event == "undefined") { event = window.event; // IE浏览器 } return event; },// 获取触发事件的元素 getTarget:function(event){ if(typeof event.srcElement == "undefined") { return event.target; }else { return event.srcElement; // IE浏览器 } },// 获取事件类型 getType:function(event) { return event.type; },// 获取按键键码 getCharCode:function(event) { if(typeof event.keyCode == "number") { return event.keyCode; // IE8-、Firefox和opera }else { return event.charCode; } },// 获取鼠标相对于文档的位置,即页面坐标位置 getPagePosition:function(event) { var pageX = event.pageX,pageY = event.pageY; if(pageX == undefined) { pageX = event.clientX + (document.body.scrollLeft || document.documentElement.scrollLeft); } if(pageY == undefined) { pageY = event.clientY + (document.body.scrollTop || document.documentElement.scrollTop); } return { pageX:pageX,pageY:pageY }; },// 阻止事件的默认行为 preventDefault:function(event) { if(event.preventDefault){ event.preventDefault(); }else { event.returnValue = false; // IE浏览器 } },// 阻止事件冒泡 stopPropagation:function(event) { if(typeof event.cancelBubble == "undefined") { event.stopPropagation(); }else { event.cancelBubble = true; // IE浏览器 } } };

测试代码

Box = document.querySelector("#Box"); Box.onclick = function(event) { event = EventUtil.getEvent(event); alert(EventUtil.getType(event)); alert(EventUtil.getTarget(event)); }; var input = document.querySelector("input"); input.onclick = function(event) { event = EventUtil.getEvent(event); EventUtil.stopPropagation(event); };

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

以上就是跨浏览器实现添加事件侦听器和跨浏览器事件对象的使用方法,希望对大家的学习有所帮助。

猜你在找的JavaScript相关文章