获取UserAgent是否包含字段:判断是否包含系统、平台、内核、载体、外壳的特有字段
const testUa = regexp => regexp.test(ua);
获取UserAgent对应字段的版本
const testVs = regexp => ua.match(regexp).toString().replace(/[^0-9|_.]/g, "").replace(/_/g, ".");方案上述准备工作完成后,我们就按照权重(系统 + 系统版本 > 平台 > 内核 + 载体 + 内核版本 + 载体版本 > 外壳 + 外壳版本)根据系统、平台、内核、载体、外壳的特有字段来归类统一浏览器运行环境 。
系统+系统版本
// 系统let system = "unknow";if (testUa(/windows|win32|win64|wow32|wow64/g)) { system = "windows"; // windows系统} else if (testUa(/macintosh|macintel/g)) { system = "macos"; // macos系统} else if (testUa(/x11/g)) { system = "linux"; // linux系统} else if (testUa(/android|adr/g)) { system = "android"; // android系统} else if (testUa(/ios|iphone|ipad|ipod|iwatch/g)) { system = "ios"; // ios系统}// 系统版本let systemVs = "unknow";if (system === "windows") { if (testUa(/windows nt 5.0|windows 2000/g)) { systemVs = "2000"; } else if (testUa(/windows nt 5.1|windows xp/g)) { systemVs = "xp"; } else if (testUa(/windows nt 5.2|windows 2003/g)) { systemVs = "2003"; } else if (testUa(/windows nt 6.0|windows vista/g)) { systemVs = "vista"; } else if (testUa(/windows nt 6.1|windows 7/g)) { systemVs = "7"; } else if (testUa(/windows nt 6.2|windows 8/g)) { systemVs = "8"; } else if (testUa(/windows nt 6.3|windows 8.1/g)) { systemVs = "8.1"; } else if (testUa(/windows nt 10.0|windows 10/g)) { systemVs = "10"; }} else if (system === "macos") { systemVs = testVs(/os x [d._]+/g);} else if (system === "android") { systemVs = testVs(/android [d._]+/g);} else if (system === "ios") { systemVs = testVs(/os [d._]+/g);}
平台
let platform = "unknow";if (system === "windows" || system === "macos" || system === "linux") { platform = "desktop"; // 桌面端} else if (system === "android" || system === "ios" || testUa(/mobile/g)) { platform = "mobile"; // 移动端}
内核+载体
let engine = "unknow";let supporter = "unknow";if (testUa(/applewebkit/g)) { engine = "webkit"; // webkit内核 if (testUa(/edge/g)) { supporter = "edge"; // edge浏览器 } else if (testUa(/opr/g)) { supporter = "opera"; // opera浏览器 } else if (testUa(/chrome/g)) { supporter = "chrome"; // chrome浏览器 } else if (testUa(/safari/g)) { supporter = "safari"; // safari浏览器 }} else if (testUa(/gecko/g) && testUa(/firefox/g)) { engine = "gecko"; // gecko内核 supporter = "firefox"; // firefox浏览器} else if (testUa(/presto/g)) { engine = "presto"; // presto内核 supporter = "opera"; // opera浏览器} else if (testUa(/trident|compatible|msie/g)) { engine = "trident"; // trident内核 supporter = "iexplore"; // iexplore浏览器}
内核版本+载体版本
// 内核版本let engineVs = "unknow";if (engine === "webkit") { engineVs = testVs(/applewebkit/[d._]+/g);} else if (engine === "gecko") { engineVs = testVs(/gecko/[d._]+/g);} else if (engine === "presto") { engineVs = testVs(/presto/[d._]+/g);} else if (engine === "trident") { engineVs = testVs(/trident/[d._]+/g);}// 载体版本let supporterVs = "unknow";if (supporter === "chrome") { supporterVs = testVs(/chrome/[d._]+/g);} else if (supporter === "safari") { supporterVs = testVs(/version/[d._]+/g);} else if (supporter === "firefox") { supporterVs = testVs(/firefox/[d._]+/g);} else if (supporter === "opera") { supporterVs = testVs(/opr/[d._]+/g);} else if (supporter === "iexplore") { supporterVs = testVs(/(msie [d._]+)|(rv:[d._]+)/g);} else if (supporter === "edge") { supporterVs = testVs(/edge/[d._]+/g);}
外壳+外壳版本
let shell = "none";let shellVs = "unknow";if (testUa(/micromessenger/g)) { shell = "wechat"; // 微信浏览器 shellVs = testVs(/micromessenger/[d._]+/g);} else if (testUa(/qqbrowser/g)) { shell = "qq"; // QQ浏览器 shellVs = testVs(/qqbrowser/[d._]+/g);} else if (testUa(/ucbrowser/g)) { shell = "uc"; // UC浏览器 shellVs = testVs(/ucbrowser/[d._]+/g);} else if (testUa(/qihu 360se/g)) { shell = "360"; // 360浏览器(无版本)} else if (testUa(/2345explorer/g)) { shell = "2345"; // 2345浏览器 shellVs = testVs(/2345explorer/[d._]+/g);} else if (testUa(/metasr/g)) { shell = "sougou"; // 搜狗浏览器(无版本)} else if (testUa(/lbbrowser/g)) { shell = "liebao"; // 猎豹浏览器(无版本)} else if (testUa(/maxthon/g)) { shell = "maxthon"; // 遨游浏览器 shellVs = testVs(/maxthon/[d._]+/g);}
推荐阅读
-
唐艺昕|张一山版韦小宝来了!唐艺昕演建宁公主,网友:角色形象神还原
-
-
抓饭体育平台|小詹姆斯利拉德点赞詹娜内衣照,这谁顶得住?
-
嘉丽侃篮球|太阳豪取复赛6连胜,新星连续2场爆发,布克35分,27分大胜雷霆
-
-
张大仙|阿泰碰瓷张大仙?声称人气已经排名第一,看到数据粉丝笑了!
-
姜素拉|韩国又一位女神宣布结婚,老公身份显神秘,曾瘦身52斤闯进娱乐圈
-
网易娱乐|范世錡《青青子衿》嘴炮技能MAX 情感真挚引共鸣
-
-
李国庆行拘期满后首发声|李国庆行拘期满后首发声:我立誓接管当当
-
-
-
趣味星座社■旧爱难放下,真情难抵挡,喜鹊牵缘,与旧爱再相守的星座,7天后
-
『鲜闻说』她穿上却短了一大截!,有种“大长腿”叫关晓彤!别人穿校服裤都嫌太长
-
中国新闻网|第26届上海电视节落幕《破冰行动》获最佳中国电视剧奖
-
【苹果】苹果外包钟爱中国大陆?库克:我们只挑最好的
-
-
浚县|危险!媒体:卫河鹤壁段决堤,有村民被围在河堤上
-
微笑的娱乐小屋|推荐现言女主文,人间芭比女配音演员VS斯文高冷酒店大亨!
-
聊聊汽车吧|温柔漂亮有魅力,堪称万人迷,让男人爱得死去活来的三大生肖女