用户代理检测

为了不在全局作用域中添加多余的变量,我们使用模块增强模式来封装检测脚本

以下是完整的用户代理字符串检测脚本,包括检测呈现引擎、平台、Window操作系统、移动设备和游戏系统

var client=function(){

    //呈现引擎

    var engine={

      ie:0,

      gecko:0,

      webkit:0,

      khtml:0,

      opera:0,

      //完整的版本号

      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,

      //移动设备

      iphone:false,

      ipod:false,

      ipad:false,

      ios:false,

      android:false,

      nokiaN:false,

      winMobile:false,

      //游戏系统

      wii:false,

      ps:false

      };

    //检测呈现引擎和浏览器

    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(browser.ver);

      }

      }else if(/MSIE([^;]+)/.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.x11=(p=="x11")||(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;

      //window 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

      };

    }();

JavaScript高级程序设计20.pdf的更多相关文章

  1. JavaScript高级程序设计4.pdf

    虽然执行环境的类型总共只有两种——全局和局部(函数),但还有其他方法延长作用域链,有些语句可以在作用域链的前端临时增加一个变量对象,执行后会被移除try-catch语句的catch块和with语句 w ...

  2. JavaScript高级程序设计61.pdf

    JSON对象 早期的JSON解析器就是使用JavaScript的eval()函数,ECMAScript5对解析JSON的行为做出了规定,定义了全局对象JSON. JSON对象有2个方法:stringi ...

  3. JavaScript高级程序设计60.pdf

    错误处理 try-catch语句 try{ //可能会导致错误的代码 }catch(error){ //在错误发生时如何处理 } error是一个包含着错误信息的对象,它有一个message属性,保存 ...

  4. JavaScript高级程序设计58.pdf

    15章 使用Canvas绘图 略 16章 HTML5脚本编程 HTML5规范了新的HTML标记和JavaScript API,以便简化创建动态Web界面的工作 跨文档消息传递 简称XDM,指来自不同域 ...

  5. JavaScript高级程序设计57.pdf

    表单序列化 首先了解一下浏览器如何将数据发送给服务器 对表单字段的名称和值进行URL编码,使用和号(&)分隔 不发送禁用的表单字段 只发送勾选的复选框和单选按钮 不发送type为“reset” ...

  6. JavaScript高级程序设计55.pdf

    输入模式 HTML5为文本字段新增了pattern属性,这个属性的值是一个正则表达式,用于匹配文本框中的值 例如,只想在允许在文本字段中输入数值 <input type="text&q ...

  7. JavaScript高级程序设计54.pdf

    过滤输入 对于一些浏览器,可以使用正则表达式里的text()测试用户按下的按键,Firefox和safari(3.1版本之前)会对向上向下.退格键和删除键触发keypress事件,在Firefox中, ...

  8. JavaScript高级程序设计53.pdf

    共有的表单字段方法 每个表单字段都有两个方法:focus()和blur(),其中focus()用于将浏览器焦点设置到表单字段,激活表单字段.可以侦听页面的load事件 EventUtil.addHan ...

  9. JavaScript高级程序设计52.pdf

    表单脚本 表单的基础知识 在HTML中,表单是由<form>元素表示的,在Javascript对应的是HTMLFormElement类型,它继承自HTMLElement,因此具有与其他HT ...

随机推荐

  1. 自动化构建jenkins配置

    1.安装jdk7+tomcat7 2.下载msi安装文件(我是win7上安装,下载地址 http://Jenkins-ci.org/),文件安装路径选择\tomcat\webapps. 3.安装成功之 ...

  2. jquery 中$('.ui-selecter',this)这样写 是什么意思 求解释 见到都是这种$("div")

    如果用$("div")是拿选择所有的div$('.ui-selecter',this)选择的是现在选项中的child里面class是ui-selecter的意思跟jQuery(th ...

  3. IMPDP hangs, session wait “wait for unread message on broadcast channel”

    昨晚有个朋友说加班在IMPDP数据, 在导入中途突然没有了进展,挂在那里不动了,impdp 窗口也没有报错, 一直等了1个多小时,说是impdp使用了parallel,怀疑是parallel参数出了问 ...

  4. UITabBar的隐藏

    方式一: // 重写导航控制器的push方法 - (void)pushViewController:(UIViewController *)viewController animated:(BOOL) ...

  5. 《转》前端性能优化----yahoo前端性能团队总结的35条黄金定律

    除了自己总结:1. 减少http请求,2.压缩并优化js/css/image 3.尽量静态页面,从简原则 4.代码规范(详见:个人知识体系思维导图) 从yahoo 新学到的: 网页内容 减少http请 ...

  6. C++判断Office版本——转载

    自:http://blog.csdn.net/lpc_china/article/details/18359145 主要原理:查询windows注册表microsoft office软件项的值来判断版 ...

  7. 使用APT减少MVP的冗余代码

    前言 不知道从何时起,移动端开发都开始采用MVP.我们在认识到MVP有点的时候,也不妨会察觉到它其实也有很多恼人的地方,比如,我们针对每种状态渲染不同的视图: private void renderI ...

  8. thinkphp我掉下的一些坑

    1.数据库连接,需要连接没有数据表前缀 如下,第二个参数必须为null,我之前写的是'',结果给我默认加了前缀 $User = M('User',Null,'DB_CONFIG2'); 2.AJAX获 ...

  9. AngularJS初体验

    最近突然发现,Coding.net真是一个神奇的网站.这各网站90%的请求都是通过ajax完成的.可以发现,不管你点任何链接,网页都不会刷新,点击浏览器的返回或前进按钮也是这样,打开chrome的开发 ...

  10. 《JavaScript高级程序设计 第3版》-学习笔记-3

    P84-P137页, 这一章看的真久,这个月事太多了.有些内容在代码注释里没提出来了 1.JS强大的数组类型,元素类型任意,提供了非常多的操作数组的方法和属性 /* 数组类型 */ //stack v ...