无为清净楼资源网 Design By www.qnjia.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.qnjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
无为清净楼资源网 Design By www.qnjia.com
暂无评论...
更新日志
2024年11月20日
2024年11月20日
- 群星 《2024好听新歌23》十倍音质 U盘音乐 [WAV分轨][1.6G]
- 群星《妙音纪念珍藏版》蓝光BSCD[WAV+CUE][1G]
- 【发烧试音】蔡克信严讯人间天籁》[原抓WAV+CUE]
- [ABC唱片]山姆泰勒《西电之声·萨克斯风》[低速原抓WAV+CUE]
- 童丽《微风细雨XRCD2》[原抓WAV+CUE]
- 群星 《车乐坊1》DTS魔音[WAV+CUE][1.7G]
- 邓丽君.2024 -《生誕70年ベスト?アルバム 沒後30年》环球日版 [WAV+分轨][993M]
- 群星《一人一首成名曲》1998 台湾金碟珍藏版[WAV+CUE][1.1G]
- 陈百强2024-《凝望》头版限量编号MQA-UHQCD[WAV+CUE]
- 测试示范《监听天碟3》头版限量编号LECD[WAV+CUE]
- 陈瑞《爱你到天荒地老HQ》头版限量[低速原抓WAV+CUE]
- 徐小凤 《徐小凤殿堂18首》24K金碟[WAV+CUE]
- 保时捷原厂车载爆棚动态试音碟《Panamera_Soundtrack》DTS[WAV分轨][1G]
- 容祖儿《小小》香港首版 [WAV+CUE][1.1G]
- 莫文蔚《拉活…》SONY [WAV+CUE][1G]