Javascript之浏览器兼容EventUtil
var EventUtil = {
//添加事件处理程序
addHandler: function (element, type, handler) {
if (element.addEventListener) {
element.addEventListener(type, handler, false);
//DOM2中定义的事件处理程序,IE9,Firefox,Safari,Chrome和Opera支持此方法。
} else if (element.attachEvent) {
element.attachEvent("on" + type, handler);
//在IE中attachEvent()方法是在全局作用域中运行的,也就是this等于window。而且如果给一个事件添加了多个处理程序,其执行顺序是逆序的。
} else {
element["on" + type] = handler;
//DOM0级方法,其只对每个事件只支持一个事件处理程序。
}
},
//移除事件处理程序
removeHandler: function (element, type, handler) {
if (element.removeEventListener) {
element.removeEventListener(type, handler, false);
//在使用移除方法时,其传入参数要和添加处理程序时相同,也就意味着添加的匿名函数将无法移除。
} else if (element.detachEvent) {
element.detachEvent("on" + type, handler);
//与上面相同,也是不可以移除匿名函数的。
//为了解决这个问题,我们可以把匿名函数的引用传入,而不是直接传入匿名函数。
} else {
element["on" + type] = null;
//DOM0级方法
}
},
//获取事件对象
getEvent: function (event) {
return event ? event : window.event;
//在兼容DOM的浏览器中,event是简单的传入和返回;在IE中,event是未定义的(undefined),而是一个window对象属性。
},
//获取事件目标
getTarget: function (event) {
return event.target || event.srcElement;
//IE中的事件目标属性是srcElement。
},
//取消事件的默认行为
//只有在cancelable属性为true时,才可以取消事件的默认行为。
preventDefault: function (event) {
if (event.preventDefault) {
event.preventDefault();
} else {
event.returnValue = false;
//IE中的事件对象有returnValue属性,默认为true,设置为false可以取消默认行为。
}
},
//取消事件的捕获或者冒泡
stopPropagation: function (event) {
if (event.stopPropagation) {
event.stopPropagation();
//可以用来取消事件捕获和冒泡。
} else {
event.cancelBubbles = true;
//兼容IE,只可以取消事件冒泡。
}
},
//获取相关元素,只对于mouseover,mouseout才包含值,对于其他事件是null。
getRelatedTarget: function (event) {
if (event.relatedTarger) {
return event.relatedTarget;
//DOM通过relatedTarget属性保存相关元素。
} else if (event.toElement) { //兼容IE,mouseout触发。
return event.toElement;
} else if (event.fromElement) { //兼容IE,mouseover事件触发。
return event.fromElement;
} else { return null; }
},
//获取鼠标点击按钮
getMouseButton:function(evsent){
if (document.implementation.hasFeature("MouseEvents","2.0")){
return event.button; //0-鼠标主按键/左键;1-鼠标中间按键/滚轮;2-鼠标次按键/右键。
} else{
switch(event.button){
case 0:
case 1:
case 5:
case 7:
return 0;
case 2:
case 6:
return 2;
case 4:
return 1;
}
}
},
//鼠标滚轮事件,获取wheelData。
getWheelData:function(event){ //向前滚动是,wheelData是120的倍数,向后滚动是-120的倍数。
if(event.wheelData){
return (client.engine.opera && client.engine.opera<9.5 ? -event.wheelData : event.wheelData);
//在opera9.5前的版本中,wheelData的正负号是颠倒的。
}
else{ return -event.detail*40;} //兼容Firefox,其鼠标滚轮信息保存在detail中,而且是向前是-3的倍数,向后是3的倍数。
},
//取得按键的字符编码
getCharCode: function(event){
if (typeof event.charCode == "number"){
return event.charCode; //IE9,Firefox,Safari,Chrome的event对象有一个charCode属性,只有发生keypress事件时才包含值。
} else {
return event.keyCode; //IE8及之前的版本和Opera在keyCode中保存字符编码。
}
}
//操作剪切板
//取得剪切板数据
getClipboardText: function(event){
var clipboardData = (event.clipboardData || window.cilpboardData);//在IE中是window对象的属性。
return clipboardData.getData("text"); //在IE中有两种数据格式text和url;其他浏览器是MIME类型,但可以用text代表text/plain。
}
//设置剪切板数据
setClipboardText: funtion(evnet,value){
if (event.clipboardData){
return event.clipboardData.setData("text/plain", value); //与以上不同的是setData方法不能识别text。
} else if (window.clipboardData){
return window.clipboardData.setData("text", value); //兼容IE
}
}
}
持续更新中……
Javascript之浏览器兼容EventUtil的更多相关文章
- JavaScript中浏览器兼容问题
浏览器兼容性问题是在实际开发中容易忽略而又最重要的一部分.我们在讲老版本浏览器兼容问题之前,首先要了解什么是能力检测,它是来检测浏览器有没有这种能力,即判断当前浏览器是否支持要调用的属性或者方法.下面 ...
- Javascript常见浏览器兼容问题
常见浏览器原生javascript兼容性问题主要分为以下几类: 一.Dom 1.获取HTML元素,兼容所有浏览器方法:document.getElementById("id")以I ...
- Javascript 字符串浏览器兼容问题
先看下不兼容的写法,若我想获取某个字符串的第几位 var str='aavvvcc'; console.info(str[0]); 这种写法 在IE 7以下的浏览器都不兼容,以下提供浏览器全兼容的方式 ...
- JavaScript之浏览器兼容问题与IE(神经病一样的浏览器)
IE是最讨厌的浏览器,没有之一.----题记 废话不说,粘上大图~
- javascript与浏览器学习(一)
待学习………… 20160421 标题:JavaScript中浏览器兼容问题 博客地址:http://www.cnblogs.com/DF-fzh/p/5408241.html 简单 ...
- Javascript不同浏览器差异及兼容方法
原文链接:http://caibaojian.com/js-ie-different-from-firefox.html javascript的各种兼容就是为了解决不同浏览器的差异性,了解其中的差异能 ...
- 多浏览器兼容用javascript获取url参数的方法比较推荐的一种
多浏览器兼容用javascript获取url参数的方法比较推荐的一种 <script language = javascript> function request(paras){ var ...
- JavaScript初学者建议:不要去管浏览器兼容
如果可以回到过去的话,我会告诉自己这句话:"初学JavaScript的时候无视DOM和BOM的兼容性" 我初学时的处境 在我初学JavaScript的时候最头痛的就是浏览器兼容问题 ...
- 在javascript中的浏览器兼容问题以及兼容浏览器汇总(默认事件,阻止冒泡,事件监听。。。)以及解决方式详解
在javascript中常见的浏览器兼容问题,以及解决方式. 在前端工作当中我们遵循这样的原则:渐进增强和优雅降级 渐进增强(progressive enhancement): 针对低版本浏览器进 ...
随机推荐
- INSTALL_FAILED_TEST_ONLY: installPackageLI. 问题解决
FAQ: Installation failed with message Failed to finalize session : INSTALL_FAILED_TEST_ONLY: install ...
- 【THUSC2017】巧克力
题目描述 “人生就像一盒巧克力,你永远不知道吃到的下一块是什么味道.” 明明收到了一大块巧克力,里面有若干小块,排成n行m列.每一小块都有自己特别的图案ci,j,它们有的是海星,有的是贝壳,有的 ...
- 【贪心/Trie】【CF1083B】 The Fair Nut and Strings
Description 有 \(k\) 个长度为 \(n\) 的只含 \(a\) 或 \(b\) 字符串,并不知道它们具体是多少,只知道它们的字典序不小于字符串 \(A\),同时不大于字符串 \(B\ ...
- Maven settings.xml配置(指定本地仓库、阿里云镜像设置)
转: 详解Maven settings.xml配置(指定本地仓库.阿里云镜像设置) 更新时间:2018年12月18日 11:14:45 作者:AmaniZ 我要评论 一.settings. ...
- pg删除账号,权限的回收问题
在pg中删除账号时,一般不能直接删除账号,要先将该账号上所有的对应权限收回,但往往这一步是比较繁琐的,可能当时赋权的对象类型很多,对象也比较多,虽然可以通过sql按照类型来收回针对整个schema的所 ...
- P2787 语文1(chin1)- 理理思维
P2787 语文1(chin1)- 理理思维 1.获取第x到第y个字符中字母k出现了多少次 2.将第x到第y个字符全部赋值为字母k 3.将第x到第y个字符按照A-Z的顺序排序 读字符串我再单个单个读我 ...
- jvm系列(三):GC算法 垃圾收集器
原文出处:纯洁的微笑 这篇文件将给大家介绍GC都有哪几种算法,以及JVM都有那些垃圾回收器,它们的工作原理. 概述 垃圾收集 Garbage Collection 通常被称为"GC" ...
- a标签伪元素选择器
a{ color: black; } /*未访问的链接*/ a:link{ color: red; } /*访问过的链接*/ a:visited{ color: green; } /*鼠标经过时*/ ...
- 在WindowsServer2008服务器上安装SQLServer2008R2 Express版
登录服务器 使用远程桌面登录Windows Server 2008 安装前的准备工作 下载SQL Server安装程序 下载Microsoft SQL Server2008 R2 RTM - Ex ...
- iframe中的历史记录问题汇总及解决方案[转]
在做页面统计的时候遇到了两个问题: 1.包含iframe的页面,在IE下按后退按钮不能刷新主页面.隐藏Iframe的src是统计程序的url,每点一次后退,就会发出一次页面加载时间请求. 2.由js动 ...