客户端检测

好东西要保留,现在看的好懵逼……@_@


 

A、在浏览器存在差别通常需要根据不同的浏览器的能力分别编写不同的代码,一下一些常用的客户端测方法

1、能力检测:在编写代码之前先检测特定的浏览器的能力,例如,脚本在调用某个函数之前,可能要先检测该函数是否存在,能力检测无法精确地检测特定的浏览器和版本

2、怪癖检测:实际上是浏览器实现中存在的bug,早期的webkit就存在一个怪癖,即为会在for-in循环中返回被隐藏的属性,怪癖检测通常涉及到运行一小段代码,然后确定浏览器是否存在某个怪癖,由于怪癖检测与能力检测相比效率更低,因此应该只在某一个怪癖会干扰脚本运行的情况下使用,怪癖检测无法精确特定的浏览器和版本

3、用户代理检测:通过检测用户代理字符串来识别浏览器,用户代理字符串中包含大量与浏览器有关的信息,包括浏览器、平台、操作系统及浏览器版本。用户代理字符串有过一段相当长的发展历史,在此期间,浏览器提供商师徒通过在用户代理字符串中添加一些欺骗性的信息,欺骗网站以为自己的浏览器是另为一个浏览器,用户代理检测需要特殊的技巧,特别是Opera会隐瞒其用户代理字符串的情况,即便如此,通过用户代理字符串任然能够检测出浏览器所用的呈现引擎以及所在的平台,包括移动设备和游戏系统

 

B、在决定使用哪种客户端检测方法时,应该优先考虑使用能力检测,怪癖检测是确定应该如何处理代码的第二选择,而用户代理检测则是客户端检测的最后一种方案(这种方法对用户代理字符串具有很强的依赖性)


 

贴个代码

  1 /**
  2  * Created by Administrator on 2017/7/19.
  3  */
  4 //完整的用户代理字符串检测脚本
  5 var client = function () {
  6 
  7     //呈现引擎
  8     var engine = {
  9         ie: 0,
 10         gecko: 0,
 11         webkit: 0,
 12         khtml: 0,
 13         opera: 0,
 14         //完整的版本号
 15         ver: null
 16     };
 17 
 18 
 19     //浏览器
 20     var browser = {
 21         //主要浏览器
 22         ie: 0,
 23         firefox: 0,
 24         safari: 0,
 25         konq: 0,
 26         opera: 0,
 27         chrome: 0,
 28         //具体的版本号
 29         ver: null
 30     };
 31 
 32 
 33     //平台,设备的操作系统
 34     var system = {
 35         win: false,
 36         mac: false,
 37         xll: false,
 38         //移动设备
 39         iphone: false,
 40         ipod: false,
 41         ipad: false,
 42         ios: false,
 43         android: false,
 44         nokiaN: false,
 45         winMobile: false,
 46         //游戏系统
 47         will: false,
 48         ps: false
 49     };
 50 
 51     //检测呈现引擎和浏览器
 52     var ua = navigator.userAgent;
 53     if (window.opera) {
 54         engine.ver = browser.ver = window.opera.version();
 55         engine.opera = browser.opera = parseFloat(engine.ver);
 56     } else if (/AppleWebKit\/(\S+)/.test(ua)) {
 57         engine.ver = RegExp.$1;
 58         engine.webkit = parseFloat(engine.ver);
 59         //确定是chrome还是Safari
 60         if (/Chrome\/(\S+)/.test(ua)) {
 61             browser.ver = RegExp.$1;
 62             browser.chrome = parseFloat(browser.ver);
 63         } else {
 64             //近似地确定版本号
 65             var safariVersion = 1;
 66             if (engine.webkit < 100) {
 67                 safariVersion = 1;
 68             } else if (engine.webkit < 312) {
 69                 safariVersion = 1.2;
 70             }
 71             else if (engine.webkit < 412) {
 72                 safariVersion = 1.3;
 73             }
 74             else {
 75                 safariVersion = 2;
 76             }
 77             browser.safari = browser.ver = safariVersion;
 78         }
 79     } else if (/KHTML\/(\S+)/.test(ua) || /Konqueror\/([^;]+)/.test(ua)) {
 80         engine.ver = browser.ver = RegExp.$1;
 81         engine.khtml = browser.konq = parseFloat(engine.ver);
 82     } else if (/rv:([^\)]+)\) Gecko\/\d{8}/.test(ua)) {
 83         engine.ver = RegExp.$1;
 84         engine.gecko = parseFloat(engine.ver);
 85         //确定是不是firefox
 86         if (/Firefox\/(\S+)/.test(ua)) {
 87             browser.ver = RegExp.$1;
 88             browser.firefox = parseFloat(browser.ver);
 89         }
 90     } else if (/MSIE ([^;]+)/.test(ua)) {
 91         engine.ver = browser.ver = RegExp.$1;
 92         engine.ie = browser.ie = parseFloat(engine.ver);
 93     }
 94 //检测浏览器
 95     browser.ie = engine.ie;
 96     browser.opera = engine.opera;
 97 
 98     //检测平台
 99     var p = navigator.platform;
100     system.win = p.indexOf("Win") == 0;
101     system.mac = p.indexOf("Mac") == 0;
102     system.xll = (p == "Xll") || (p.indexOf("Linux") == 0);
103 
104     //检测Windows操作系统
105     if (system.win) {
106         if (/Win(?:dows)?([^do]{2})\s?(\d+\.\d+)?/.test(ua)) {
107 
108             if (RegExp.$1 == "NT") {
109                 switch (RegExp.$2) {
110                     case "5.0":
111                         system.win = "2000";
112                         break;
113                     case "5.1":
114                         system.win = "XP";
115                         break;
116                     case "6.0":
117                         system.win = "Vista";
118                         break;
119                     case "6.1":
120                         system.win = "7";
121                         break;
122                     default :
123                         system.win = "NT";
124                         break;
125                 }
126             } else if (RegExp.$1 == "9x") {
127                 system.win = "ME";
128             } else {
129                 system.win = RegExp.$1;
130             }
131         }
132     }
133 
134     //移动设备
135     system.iphone = ua.indexOf("iPhone") > -1;
136     system.ipod = ua.indexOf("iPod") > -1;
137     system.ipad = ua.indexOf("iPad") > -1;
138     system.nokiaN = ua.indexOf("NokiaN") > -1;
139     //windos mobile
140     if (system.win == "CE") {
141         system.winMobile = system.win;
142     } else if (system.win == "Ph") {
143         if (/Windows Phone OS (\d+. \d)/.test(ua)) {
144             system.win = "Phone";
145             system.winMobile = parseFloat(RegExp.$1);
146         }
147     }
148 //检测iOS 版本
149     if (system.mac && ua.indexOf("Mobile") > -1) {
150         if (/CPU (?:iPhone )?OS (\d+_\d+)/.test(ua)) {
151             system.ios = parseFloat(RegExp.$1.replace("_", "."));
152         } else {
153             system.ios = 2;//不能真正检测出来,所以只能猜测
154         }
155     }
156     //检测Android版本
157     if (/Android (\d+\. \d+)/.test(ua)) {
158         system.android = parseFloat(RegExp.$1);
159     }
160     //游戏系统
161     system.will = ua.indexOf("Wii") > -1;
162     system.ps = /playstation/i.test(ua);
163     //返回这些对象
164     return{
165         engine:engine,
166             browser: browser,
167             system: system
168     };
169 
170 }();

 

posted @ 2017-07-19 20:14  张洪源  阅读(149)  评论(0编辑  收藏  举报