JavaScript 判断国内外浏览器类型和内核(含360,QQ
2020-01-08 本文已影响0人
天涯的me
在开发时某些环境问题会给导致项目运行异常,如不同浏览器的同款内核下,有些程序的表现不尽相同,如360的加壳chrome内核和谷歌浏览器的chrome内核,但是在不能更换浏览器的情况下,就尽量需要根据环境的类型做判断来避免某些错误,提升用户体验。
关于判断浏览器的内核和类型,有许多资料可供查阅。这里记录一款一个比较好用的插件:browser.js
插件git地址:https://github.com/yunnysunny/browser.js
目前该插件还存在bug,对于360安全浏览器和极速浏览器还不能区分开,返回的结果都是一样的。
该插件对于IE内核的浏览器类型没有进行判断。仅仅是针对chrome内核的浏览器类型做处理。
下面是本人在源码的基础上增加的一个可支持IE内核下浏览器类型的判断,其他判断都没改变。
代码的返回JSON格式如下:
imagebrowser.js
(function() {
var packageName = 'brw';
if(!window[packageName]) {
window[packageName] = {};
window[packageName]["browserInfo"] = {};
}
var MAX_360_CHROME_VERSION = 69; //以360极速浏览器的最大内核版本为准
function getIOSVersion(ua) {
if(/cpu (?:iphone )?os (\d+_\d+)/.test(ua)) {
return parseFloat(RegExp.$1.replace("_", "."));
} else {
return 2;
}
}
function _mime(where, value, name, nameReg) {
var mimeTypes = window.navigator.mimeTypes,
i;
for(i in mimeTypes) {
if(mimeTypes[i][where] == value) {
if(name !== undefined && nameReg.test(mimeTypes[i][name])) return !0;
else if(name === undefined) return !0;
}
}
return !1;
}
var browser360 = {
result: "Chrome",
details: {
Chrome: 5,
Chromium: 0,
_360SE: 0,
_360EE: 0
},
sorted: ["Chrome", "360SE", "360EE", "Chromium"],
check: function() {
var init = {
Chrome: 5,
Chromium: 0,
_360SE: 0,
_360EE: 0
};
var plugins = window.navigator.plugins;
var webstore = window.chrome.webstore;
var webstoreLen = Object.keys(webstore).length;
var pluginsLen = plugins.length;
if(window.clientInformation.languages ||
(init._360SE += 8), /zh/i.test(navigator.language) &&
(init._360SE += 3, init._360EE += 3), window.clientInformation.languages) {
var lanLen = window.clientInformation.languages.length;
if(lanLen >= 3) {
(init.Chrome += 10, init.Chromium += 6);
} else if(2 == lanLen) {
init.Chrome += 3, init.Chromium += 6, init._360EE += 6;
} else if(1 == lanLen) {
init.Chrome += 4, init.Chromium += 4;
}
}
var pluginFrom,
maybe360 = 0;
for(var r in plugins) {
if(pluginFrom = /^(.+) PDF Viewer$/.exec(plugins[r].name)) {
if("Chrome" == pluginFrom[1]) {
init.Chrome += 6,
init._360SE += 6,
maybe360 = 1;
} else if("Chromium" == pluginFrom[1]) {
init.Chromium += 10,
init._360EE += 6,
maybe360 = 1;
}
} else if("np-mswmp.dll" == plugins[r].filename) {
init._360SE += 20, init._360EE += 20;
}
}
maybe360 || (init.Chromium += 9);
if(webstoreLen <= 1) {
init._360SE += 7;
} else {
init._360SE += 4;
init.Chromium += 3;
if(pluginsLen >= 30) {
init._360EE += 7, init._360SE += 7, init.Chrome += 7;
} else if(pluginsLen < 30 && pluginsLen > 10) {
init._360EE += 3, init._360SE += 3, init.Chrome += 3;
} else {
init.Chromium += 6;
}
}
var m = new Object();
m.Chrome = init.Chrome,
m.Chromium = init.Chromium,
m["360SE"] = init._360SE,
m["360EE"] = init._360EE;
var s = [];
for(var u in m) {
s.push([u, m[u]]);
}
s.sort(function(e, i) {
return i[1] - e[1]
});
this.sorted = s;
this.details = init;
this.result = s[0][0] || '';
return this.result.toLowerCase();
}
};
/**
* 获取国内加壳浏览器类型
*/
function _getShellerType() {
var brwType = "",
appVersion = window.navigator.appVersion,
external = window.external;
if(external && 'SEVersion' in external) { // 搜狗浏览器
brwType = 'sougou';
} else if(external && 'LiebaoGetVersion' in external) { // 猎豹浏览器
brwType = 'liebao';
} else if(/QQBrowser/.test(appVersion)) { //qq浏览器
brwType = 'qq';
} else if(/Maxthon/.test(appVersion)) { //遨游浏览器
brwType = 'maxthon';
} else if(/TaoBrowser/.test(appVersion)) { //淘宝浏览器
brwType = 'taobao';
} else if(/BIDUBrowser/.test(appVersion)) { //百度浏览器
brwType = 'baidu';
} else if(/UBrowser/.test(appVersion)) { //UC浏览器
brwType = 'uc';
}
return brwType;
}
/**
* 获取 Chromium 内核浏览器类型
* @link http://www.adtchrome.com/js/help.js
* @link https://ext.chrome.360.cn/webstore
* @link https://ext.se.360.cn
* @return {String}
* 360ee 360极速浏览器
* 360se 360安全浏览器
* sougou 搜狗浏览器
* liebao 猎豹浏览器
* chrome 谷歌浏览器
* '' 无法判断
*/
function _getChromiumType(version) {
if(window.scrollMaxX !== undefined) return '';
var doc = document;
var _track = 'track' in doc.createElement('track');
var chromeBrowserType = _getShellerType();
if(chromeBrowserType != "") {
return chromeBrowserType;
}
if(window.navigator.vendor && window.navigator.vendor.indexOf('Opera') == 0) { //opera
return 'opera';
}
var p = navigator.platform.toLowerCase();
if(p.indexOf('mac') == 0 || p.indexOf('linux') == 0) {
return 'chrome';
}
if(parseInt(version) > MAX_360_CHROME_VERSION) {
return 'chrome';
}
return browser360.check();
}
var client = function() {
var browser = {};
var ua = navigator.userAgent.toLowerCase();
console.log(ua)
var s;
if(s = ua.match(/rv:([\d.]+)/)) {
browser.name = 'ie';
browser['ie'] = s[1];
if(ua.indexOf("wow") > -1) {
browser['type'] = _getShellerType() ? _getShellerType() : "360";
} else {
browser['type'] = "IE";
}
} else if(s = ua.match(/msie ([\d.]+)/)) {
browser.name = 'ie';
browser['ie'] = s[1];
if(ua.indexOf("wow") > -1) {
browser['type'] = _getShellerType() ? _getShellerType() : "360";
} else {
browser['type'] = "IE";
}
} else if(s = ua.match(/edge\/([\d.]+)/)) {
browser.name = 'edge';
browser['edge'] = s[1];
browser['type'] = "edge";
} else if(s = ua.match(/firefox\/([\d.]+)/)) {
browser.name = 'firefox';
browser['firefox'] = s[1];
browser['type'] = "firefox";
} else if(s = ua.match(/chrome\/([\d.]+)/)) {
browser.name = 'chrome';
browser['chrome'] = s[1];
var type = _getChromiumType(browser['chrome']);
if(type) {
browser['chrome'] += '(' + type + ')';
browser['type'] = type;
}
} else if(s = ua.match(/opera.([\d.]+)/)) {
browser.name = 'opera';
browser['opera'] = s[1];
browser['type'] = "opera";
} else if(s = ua.match(/version\/([\d.]+).*safari/)) {
browser.name = 'safari';
browser['safari'] = s[1];
browser['type'] = "safari";
} else {
browser.name = 'unknown';
browser['unknow'] = 0;
}
var system = {};
//detect platform
// var p = navigator.platform.toLowerCase();
if(ua.indexOf('iphone') > -1) {
system.name = 'iphone';
system.iphone = getIOSVersion(ua);
} else if(ua.indexOf('ipod') > -1) {
system.name = 'ipod';
system.ipod = getIOSVersion(ua);
} else if(ua.indexOf('ipad') > -1) {
system.name = 'ipad';
system.ipad = getIOSVersion(ua);
} else if(ua.indexOf('nokia') > -1) {
system.name = 'nokia';
system.nokia = true;
} else if(/android (\d+\.\d+)/.test(ua)) {
system.name = 'android';
system.android = parseFloat(RegExp.$1);
} else if(ua.indexOf("win") > -1) {
system.name = '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;
case "6.2":
system.win = "8";
break;
case "6.3":
system.win = "8.1";
break;
case '10.0':
system.win = '10';
break;
default:
system.win = "NT";
break;
}
} else if(RegExp["$1"] == "9x") {
system.win = "ME";
} else {
system.win = RegExp["$1"];
}
}
} else if(ua.indexOf("mac") > -1) {
system.name = 'mac';
} else if(ua.indexOf('linux') > -1) {
system.name = 'linux';
}
var str = system.name + (system[system.name] || '') + '|' + browser.name + browser[browser.name];
var isMobile = system.android || system.iphone || system.ios || system.ipad || system.ipod || system.nokia;
return {
browser: browser,
system: system,
isMobile: isMobile,
string: str
};
}();
window[packageName]['browserInfo'] = client;
})();
如何调用。
var browser = brw.browserInfo || {};
document.getElementById('info').innerHTML = '浏览器:'+ JSON.stringify( browser.browser) + ',操作系统:'+ JSON.stringify( browser.system)+'<br/>'+browser.string;
效果图
image希望可以对于有需要的兄弟有所帮助。