一、检测

用于用户代理检测,检测范围包括浏览器引擎、平台、Windows、移动设备和游戏系统等

/*
*用户代理检测脚本,检测范围包括浏览器引擎、平台、Windows、移动设备和游戏系统
*/
var client = function()
{
//呈现引擎
var engine = {
ie:0, //ie
gecko:0, //火狐
webkit:0, //chrome和safari
khtml:0, //Linux下的Konqueror
opera:0, //opera
ver:null //完整版本号
}; //浏览器
var browser = {
ie:0,
firefox:0,
safari:0,
konq:0,
opera:0,
chrome:0,
ver:null //具体版本号
}; //平台、设备和操作系统
var system = {
//操作系统
win:false,
mac:false,
xll:false, //UNIX //移动设备
iphone:false,
ipod:false,
ipad:false,
ios:false,
android:false,
nokiaN:false, //诺基亚
winMobile:false, //windows mobile //游戏系统
wii:false, //Wii
ps:false //Playstation 3
}; //检测呈现引擎和浏览器
var ua = navigator.userAgent;
if(window.opera)
{
engine.ver = browser.ver = window.opera.version();
engine.opera = browser.opera = parseFloat(engine.ver);
}
else if(/AppleWebkit\/(\S+)/.test(ua ))
{
engine.ver = RegExp["$1"];
engine.webkit = parseFloat(engine.ver); //确定是chrome还是safari
if(/Chrome\/(\S+)/.test(ua))
{
browser.ver = RegExp["$1"];
browser.chrome = parseFloat(browser.ver);
}
else if(/Version\/(\S+)/.test(ua))
{
browser.ver = RegExp["$1"];
browser.safari = parseFloat(browser.ver);
}
else
{
// 近似确定版本号
var safariVersion = 1;
if(engine.webkit < 100)
{
safariVersion = 1;
}
else if(engine.webkit < 312)
{
safariVersion = 1.2;
}
else if(engine.webkit < 412)
{
safariVersion = 1.3;
}
else
{
safariVersion = 2;
}
browser.safari = browser.ver = safariVersion;
}
}
else if(/KHTML\/(\S+)/.test(ua) || /Konqueror\/([^; ]+)/.test(ua))
{
engine.ver = browser.ver = RegExp["$1"];
engine.khtml = browser.konq = parseFloat(engine.ver);
}
else if (/rv:([^\)]+)\) Gecko\/\d{8}/.test(ua))
{
engine.ver = RegExp["$1"];
engine.gecko = parseFloat(engine.ver); // 确定是不是FireFox
if(/firefox\/(\S+)/test(ua))
{
browser.ver = RegExp["$1"];
browser.firefox = parseFloat(engine.ver);
}
}
else if(/MISE ([^; ]+)/.test(ua))
{
engine.ver = browser.ver = RegExp["$1"];
engine.ie = browser.ie = parseFloat(engine.ver);
} // 检测浏览器
browser.ie = engine.ie;
browser.opera = engine.opera; // 检测平台
var p = navigator.platform;
system.win = p.indexOf("Win") == 0;
system.mac = p.indexOf("Mac") == 0;
system.xll = (p == "xll") || (p.indexOf("Linux") == 0); // 检测windows操作系统
if(system.win)
{
if(/Win(?:dows )?([^do]{2})\s?(\d+\.\d+)?/.test(ua))
{
if(RegExp["$1"] == "NT")
{
switch(RegExp["$2"])
{
case "5.0":
system.win = "2000";
break;
case "5.1":
system.win = "XP";
break;
case "6.0":
system.win = "Vista";
break;
case "6.1":
system.win = "7";
break;
default:
system.win = "NT";
break;
}
}
else if(RegExp["$1"] == "9x")
{
system.win = "ME";
}
else
{
system.win = RegExp["$1"];
}
}
} // 移动设备
system.iphone = ua.indexOf("iPhone") > -1;
system.ipod = ua.indexOf("iPod") > -1;
system.ipad = ua.indexOf("iPad") > -1;
system.nokiaN = ua.indexOf("NokiaN") > -1; // windows mobile
if(system.win == "CE")
{
system.winMobile = system.win;
}
else if(system.win == "Ph")
{
if(/Windows Phone OS (\d+.\d+)/.test(ua))
{
system.win = "Phone";
system.winMobile = parseFloat(RegExp["$1"]);
}
} // 检测IOS版本
if(system.mac && ua.indexOf("Mobile") > -1)
{
if(/CPU (?:iPhone )?OS (\d+_\d+)/.test(ua))
{
system.ios = parseFloat(RegExp.$1.replace("_","."));
}
else
{
system.ios = 2;
}
} // 检测Android
if(/Android (\d+\.\d+)/.test(ua))
{
system.android = parseFloat(RegExp.$1);
} // 游戏系统
system.wii = ua.indexOf("Wii") > -1;
system.ps = /playstation/i.test(ua); // 返回结果
return {
engine:engine,
browser:browser,
system:system
};
}();

二、事件的跨浏览器处理

/* *参数:ele-->元素,type-->事件类型,不带on,handler-->事件处理程序 */ var EventHandler = { addHandler:function(ele,type,handler){               //添加处理程序 // DOM2级事件处理 if(ele.addEventListener){ ele.addEventListener(type,handler,false); }else if(ele.attachEvent){ ele.attachEvent("on"+type,handler); }else{ // DOM0级事件处理 ele["on"+type] = handler; } }, removeHandler:function(ele,type,handler){            //删除处理程序 if(ele.removeEventListener){ ele.removeEventListener(type,handler,false); }else if(ele.detachEvent){ ele.detachEvent("on"+type,handler); }else{ ele["on"+type] = null; } },

getEvent: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;

}

},

stopPropagation:function(event){ //阻止事件流

if(event.stopPropagation){

event.stopPropagation();

}else{

event.cancelBubble = true;

}

},

getRelatedTarget:function(event){ //在mouseover和mouseout中获取相关元素

if(event.relatedTarget){

return event.relatedTarget;

}else if(event.toElement){ //IE8及以下版本不支持relatedTarget属性

return event.toElement;

}else if(event.fromElement){

return event.fromElement;

}else{

return null;

}

},

getWheelDelta:function(event){ //获取鼠标滚轮数据

if(event.wheelDelta){

return (client.engine.opera && client.engine.opera < 9.5?-event.wheelDelta:event.wheelDelta);

}else{

return –event.detail*40; //针对FireFox

}

},

getCharCode:function(event){ //获取字符编码

if(event.charCode == “number”){

return event.charCode;

}else{

return event.keyCode;

}

}, };

存在的不足之处敬请见谅。

原文首发:http://www.ido321.com/1403.html

DOM(十四):代理检测和事件处理(跨浏览器)的更多相关文章

  1. Android入门(十四)内容提供器-实现跨程序共享实例

    原文链接:http://www.orlion.ga/661/ 打开SQLite博文中创建的 DatabaseDemo项目,首先将 MyDatabaseHelper中使用 Toast弹出创建数据库成功的 ...

  2. Java设计模式菜鸟系列(十四)代理模式建模与实现

    转载请注明出处:http://blog.csdn.net/lhy_ycu/article/details/39856435 代理模式(Proxy):代理模式事实上就是多一个代理类出来,替原对象进行一些 ...

  3. .NET Core实战项目之CMS 第十四章 开发篇-防止跨站请求伪造(XSRF/CSRF)攻击处理

    通过 ASP.NET Core,开发者可轻松配置和管理其应用的安全性. ASP.NET Core 中包含管理身份验证.授权.数据保护.SSL 强制.应用机密.请求防伪保护及 CORS 管理等等安全方面 ...

  4. 爱创课堂每日一题第五十四天- 列举IE 与其他浏览器不一样的特性?

    IE支持currentStyle,FIrefox使用getComputStyle IE 使用innerText,Firefox使用textContent 滤镜方面:IE:filter:alpha(op ...

  5. JS原生事件处理(跨浏览器)

    一.关于获取事件对象 FF有点倔强,只支持arguments[0],不支持window.event.这次真的不怪IE,虽然把event作为window的属性不合规范,但大家都已经默许这个小问题存在了, ...

  6. 代理模式 PROXY Surrogate 结构型 设计模式(十四)

    代理模式 PROXY 别名Surrogate 意图 为其他的对象提供一种代理以控制对这个对象的访问. 代理模式含义比较清晰,就是中间人,中介公司,经纪人... 在计算机程序中,代理就表示一个客户端不想 ...

  7. JS事件流、DOM事件流、IE事件处理、跨浏览器事件处理、事件对象与类型

    事件的移除 removeEventListener() 第二个参数需要指定要移除的事件句柄,不能是匿名函数,因为无法识别 想要移除成功,那么三个参数必须跟addEventListener中的三个完全一 ...

  8. JavaScript(第二十四天)【事件对象】

    JavaScript事件的一个重要方面是它们拥有一些相对一致的特点,可以给你的开发提供更多的强大功能.最方便和强大的就是事件对象,他们可以帮你处理鼠标事件和键盘敲击方面的情况,此外还可以修改一般事件的 ...

  9. JavaScript高级程序设计:第十四章

    第十四章 一.表单的基础知识 在HTML中,表单是由<form>元素来表示的,而在javascript中,表单对应的则是HTMLFormElement类型.HTMLFormElement继 ...

随机推荐

  1. 缓存方案:本地guavaCache, 远程redis?

    线程内部缓存:a. 局部变量HashMap, 方法间传递  b. 使用ThreadLocal 本地缓存:单jvm内共享 可以使用(Concurrent)HashMap自己实现,也可以使用GuavaCa ...

  2. Nmap工具使用

    Nmap是一款网络扫描和主机检测的非常有用的工具. Nmap是不局限于仅仅收集信息和枚举,同时可以用来作为一个漏洞探测器或安全扫描器.它可以适用于winodws,linux,mac等操作系统.Nmap ...

  3. Yii2 前台控制器访问权限控制

    class BaseController extends Controller { public function behaviors() { return [ 'access' => [ 'c ...

  4. Python数据可视化--matplotlib

    抽象化|具体化: 如盒形图 | 现实中的图 功能性|装饰性:没有装饰和渲染 | 包含艺术性美学上的装饰 深度表达|浅度表达:深入层次的研究探索数据 | 易于理解的,直观的表示 多维度|单一维度:数据的 ...

  5. 阿里云服务器mail 命令发邮件

    一.申请开通25端口 https://yundun.console.aliyun.com/?spm=5176.2020520001.aliyun_topbar.188.KbmgKc&p=sc# ...

  6. webstorm中.vue报错(es6语法报错)-转

    1.webstorm中es6语法报错,解决方法: 打开 Settings => Languages & Frameworks => Javascript把 Javascript L ...

  7. DRF之权限认证频率组建

    认证组件 很久很久以前,Web站点只是作为浏览服务器资源(数据)和其他资源的工具,甚少有什么用户交互之类的烦人的事情需要处理,所以,Web站点的开发这根本不关心什么人在什么时候访问了什么资源,不需要记 ...

  8. [转]如何在.NET MVC中使用jQuery并返回JSON数据

    本文转自:http://blog.sina.com.cn/s/blog_48e42dc90100xp1p.html 二.开始实践 - jQuery端 假设我们要从服务器端获取一个文章列表,并把文章条目 ...

  9. C语言实现通用链表初步(一)

    注意:本文讨论的是无头单向非循环链表. 假设不采用Linux内核链表的思路,怎样用C语言实现通用链表呢? 一种常用的做法是: typedef int element_t; struct node_in ...

  10. 测试阿里云1核2g轻量级服务器的吞吐量

    使用jmeter对部署的dbshop发起请求,单线程5000次请求 面板为宝塔界面 吞吐量大概在每秒48个请求左右.可以看出阿里云1核2g服务器其实并不能进行实战,只是新手练手而已. 阿里云另一种ec ...