#JavaScript学习#第九章:客户端检测

281 阅读2分钟

Tips: 内容为知识梳理


目录

  1. 能力检测

  2. 怪癖检测

  3. 用户代理检测


这一章主要讲的是如何检测WEB客户端是哪一个浏览器 以下是三种方法

1. 能力检测

目标是识别浏览器能力,基本模式如下:

if (object.propertyInQuestion){     
//使用 object.propertyInQuestion 
} 

能力检测有两个重要概念:

  • 先检测达成目的的最常用的特性
  • 必须测试实际要用得到的特性

1.1 更可靠的能力检测

能力检测对于想知道某个特性是否会按照适当方式行事非常有用。 尽量使用typeof进行能力检测,如下

//这样更好:检查 sort 是不是函数 
function isSortable(object){      
return typeof object.sort == "function"; 
}

1.2 能力检测不代表浏览器检测

检测某个或几个特性并不能确定浏览器,最好是一次检测所有相关特性

2. 怪癖检测

识别浏览器特殊行为,它是想知道浏览器有什么bug

var hasDontEnumQuirk = function(){ 
var o = { toString : function(){} };     
for (var prop in o){ 
if (prop == "toString"){             
return false;         
}     
} 
return true; 
}();

3. 用户代理检测

3.1 用户代理字符串检测技术

通过用户代理字符串检测特定浏览器 代码均放在最后

1. 识别呈现引擎

先识别Opera

if (window.opera){     
engine.ver = window.opera.version();     
engine.opera = parseFloat(engine.ver); 
}

再识别WebKit

var ua = navigator.userAgent; 
if (window.opera){     
engine.ver = window.opera.version();     
engine.opera = parseFloat(engine.ver);  
} else if (/AppleWebKit\/(\S+)/.test(ua)){     
engine.ver = RegExp["$1"];     
engine.webkit = parseFloat(engine.ver);  
}

再识别KHTML

var ua = navigator.userAgent; 
if (window.opera){     
engine.ver = window.opera.version();     
engine.opera = parseFloat(engine.ver);  
} else if (/AppleWebKit\/(\S+)/.test(ua)){     
engine.ver = RegExp["$1"];     
engine.webkit = parseFloat(engine.ver); 
} else if (/KHTML\/(\S+)/.test(ua) || /Konqueror\/([^;]+)/.test(ua)){     
engine.ver = RegExp["$1"];     
engine.khtml = parseFloat(engine.ver); 
}

再识别Gecko 最后是IE

2. 识别浏览器

代码见末尾

3. 识别平台

目前三大主流平台是Windows、Mac和Unix

4. 识别Windows操作系统

为了检测不同的windows操作系统必须使用正则表达式 具体操作不在这里演示

5. 识别移动设备
6. 识别游戏系统

如任天堂、playstation3和内置Web浏览器

3.2 完整代码

下面就是用户代理字符串检测的完整代码了

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,         
x11: 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; 
//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             }; 
}(); 
client