幽灵资源网 Design By www.bzswh.com
本文特意为跨浏览器实现添加事件侦听器和跨浏览器事件对象的使用方法做了下总结,并把这些方法打包,欢迎大家学习。
打包的一个EventUtil对象
var 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, type, handler) {
// IE9+、Firefox、Safari、chrome和Opera
if(element.addEventListener) {
element.removeEventListener(type, handler, false);
}
// IE8-
else if(element.attachEvent) {
element.detachEvent("on" + type, handler);
}
},
// 获取事件对象
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浏览器
}
}
};
测试代码
<div id="box" style="color:red;width: 100%;height:200px;" > <input type="button" value="点击" id="btn" /> </div> <a href="http://www.test.com" id="a">test</a>
var 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);
};
以上就是跨浏览器实现添加事件侦听器和跨浏览器事件对象的使用方法,希望对大家的学习有所帮助。
标签:
js,事件侦听器,事件对象
幽灵资源网 Design By www.bzswh.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
幽灵资源网 Design By www.bzswh.com
暂无评论...
稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!
昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。
这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。
而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?