Navigator 对象,能够清楚地知道浏览器的相关信息

Navigator 对象属性

appCodeName属性

功能:返回浏览器的代码名。该属性是一个只读的字符串。

语法:navigator.appCodeName

总结:在所有以Netscape代码为基础的浏览器中,它的值是"Mozilla"。为了兼容起见,在Microsoft的浏览器中,它的值也是"Mozilla",同时在safari在浏览器的console里运行navigator.appCodeName得出的结果还是"Mozilla"。所以这个看起来并不实用,因为IE、chrome、safari返回的都是“Mozilla”;

appName属性

功能:返回所使用浏览器的名称。该属性是一个只读的字符串。

语法:navigator.appName

总结:由于兼容性问题,HTML5 规范允许该属性返回 "Netscape" 。在chrome、safari的里面都是返回"Netscape"。该属性并不一定能返回正确的浏览器名称。在基于 Gecko 的浏览器 (例如 Firefox)和基于 WebKit 的浏览器(例如 Chrome 和 Safari)中,返回的浏览器名称都是 "Netscape"。

appVersion属性【已废弃】

功能:返回浏览器的平台和版本信息。该属性是一个只读的字符串。

语法:navigator.appVersion

总结:它可能只包含一个版本数字,如 "5.0",还可能包含一些其他的相关信息。由于兼容性问题,HTML5规范允许该属性返回 "4.0"。不要指望该属性返回正确的值。该特性已经从 Web 标准中删除,虽然一些浏览器目前仍然支持它,但也许会在未来的某个时间停止支持,请尽量不要使用该特性。

browserLanguage属性【大部分浏览器尝试也都比较支持,尽量不使用】

功能:返回当前浏览器的语言。该属性是一个只读的字符串。

语法:navigator.browserLanguage

总结:--

cookieEnabled属性【大部分浏览器尝试也都比较支持,尽量不使用】

功能:返回指明浏览器中是否启用 cookie 的布尔值。该属性是一个只读的字符串。

语法:navigator.cookieEnabled

总结:--

cpuClass属性

功能:返回浏览器系统的 CPU 等级。该属性是一个只读的字符串。

语法:navigator.cpuClass

总结:--

platform属性

功能:返回运行浏览器的操作系统平台。该属性是一个只读的字符串。

语法:navigator.platform

总结:platform 可能是: "Win32", "Linux i686", "MacPPC", "MacIntel", 等,在一定程度上可以用来区分移动端和pc端,但不是很好的方案。

systemLanguage属性【大部分浏览器尝试也都比较支持,尽量不使用】

功能:返回 OS 使用的默认语言。该属性是一个只读的字符串。

语法:navigator.systemLanguage

总结:--

product属性

功能:该属性返回当前浏览器的产品名称。该属性是一个只读的字符串。

语法:navigator.product

总结:该属性不一定返回一个真实的产品名称。Gecko 和 WebKit 浏览器返回 "Gecko" 作为该属性的值。

userAgent属性【重点】

功能:返回当前浏览器发送服务器的用户代理(user-agent)头部的值(字符串)。该属性是一个只读的字符串。

语法:navigator.userAgent

总结:先看看chrome、safari、ios、android的返回值:

 1 chrome:
 2     Mozilla/5.0 
 3     (Macintosh; Intel Mac OS X 10_12_6) 
 4     AppleWebKit/537.36 (KHTML, like Gecko) 
 5     Chrome/61.0.3163.91 Safari/537.36
 6 safari:
 7     Mozilla/5.0 
 8     (Macintosh; Intel Mac OS X 10_12_6) 
 9     AppleWebKit/604.1.38 (KHTML, like Gecko) Version/11.0 
10     Safari/604.1.38
11 ios11刘海X:
12     Mozilla/5.0 
13     (iPhone; CPU iPhone OS 11_0 like Mac OS X) 
14     AppleWebKit/604.1.38 (KHTML, like Gecko) 
15     Version/11.0 Mobile/15A372 Safari/604.1
16 ipad:
17     Mozilla/5.0 
18     (iPad; CPU OS 9_1 like Mac OS X) 
19     AppleWebKit/601.1.46 (KHTML, like Gecko)
20     Version/9.0 Mobile/13B143 Safari/601.1
21 galxy sansum:
22     Mozilla/5.0 
23     (Linux; Android 5.0; SM-G900P Build/LRX21T) 
24     AppleWebKit/537.36 (KHTML, like Gecko) 
25     Chrome/61.0.3163.91 Mobile Safari/537.36
26 安装uc浏览器:
27     Mozilla/5.0 
28     (Linux; U; Android 6.0.1; zh-CN; Mi Note 2 Build/MXB48T)
29     AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 
30     Chrome/40.0.2214.89 UCBrowser/11.4.9.941 Mobile Safari/537.36
31 winphone:
32     Mozilla/5.0 
33     (Linux; Android 5.1.1; Nexus 6 Build/LYZ28E) 
34     AppleWebKit/537.36 (KHTML, like Gecko) 
35     Chrome/61.0.3163.91 Mobile Safari/537.36
36 hybrid方法的可能:
37     Mozilla/5.0 
38     (iPhone; CPU iPhone OS 11_0 like Mac OS X) 
39     AppleWebKit/604.1.38 (KHTML, like Gecko) 
40     Mobile/15A372 weibo/80011134

 一般来讲,它是在 navigator.appCodeName 的值之后加上斜线和 navigator.appVersion 的值构成的。

例子:

  • 判断当前页面所在的环境是不是微信内置浏览器
function isWeiXin () {
  var ua = window.navigator.userAgent.toLowerCase();
  if (ua.match(/MicroMessenger/i) == 'micromessenger') {
    return true;
  } else {
    return false;
  }
}
  • 判断苹果、安卓、pc
if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent)) { //判断iPhone|iPad|iPod|iOS
  window.location.href ="iPhone.html";
} else if (/(Android)/i.test(navigator.userAgent)) {  //判断Android
  window.location.href ="Android.html";
} else { //pc
  window.location.href ="pc.html";
};
  • 正则表达式判断浏览器类型
function userBrowser(){   
    var browserName=navigator.userAgent.toLowerCase();   
    if(/msie/i.test(browserName) && !/opera/.test(browserName)){   
        alert("IE");   
        return ;   
    }else if(/firefox/i.test(browserName)){   
        alert("Firefox");   
        return ;   
    }else if(/chrome/i.test(browserName) && /webkit/i.test(browserName) && /mozilla/i.test(browserName)){   
        alert("Chrome");   
        return ;   
    }else if(/opera/i.test(browserName)){   
        alert("Opera");   
        return ;   
    }else if(/webkit/i.test(browserName) &&!(/chrome/i.test(browserName) && /webkit/i.test(browserName) && /mozilla/i.test(browserName))){   
        alert("Safari");   
        return ;   
    }else{   
        alert("unKnow");   
    }   
}  

userLanguage属性【大部分浏览器尝试也都比较支持,尽量不使用】

功能:返回 OS 的自然语言设置。该属性是一个只读的字符串。

语法:navigator.userLanguage

总结:--

作用(navigator.userAgent简称UA)

  • 统计用户浏览器使用情况。有些浏览器说被多少人使用了,实际上就可以通过判断每个IP的UA来确定这个IP是用什么浏览器访问的,以得到使用量的数据。
  • 根据用户使用浏览器的不同,显示不同的排版从而为用户提供更好的体验。有些网站会根据这个来调整打开网站的类型,如是手机的就打开wap,显示非手机的就打开pc常规页面。用手机访问谷歌和电脑访问是不一样的,这些是谷歌根据访问者的UA来判断的。
posted @ 2019-03-20 17:47  jameBo  阅读(927)  评论(0编辑  收藏  举报