终极合体
根据以上的条件判断获得的变量如下,我们可以把它们合并成一个对象输出 。这样就可以输出一个清晰的浏览器运行环境,后面想干嘛就干嘛了,多方便 。
本文重点探究方案的可行性,没有过多考虑到代码的优化,所以条件判断使用得有些多,如果有什么方法能优化下代码,减少条件判断,可以在下方评论提个建议哟 。
- system:系统
- systemVs:系统版本
- platform:平台
- engine:内核
- engineVs:内核版本
- supporter:载体
- supporterVs:载体版本
- shell:外壳
- shellVs:外壳版本
function BrowserType() { const ua = navigator.userAgent.toLowerCase(); const testUa = regexp => regexp.test(ua); const testVs = regexp => ua.match(regexp).toString().replace(/[^0-9|_.]/g, "").replace(/_/g, "."); // 接上以上if...else条件判断 // ...... // 获取到system、systemVs、platform、engine、engineVs、supporter、supporterVs、shell、shellVs return Object.assign({ engine, // webkit gecko presto trident engineVs, platform, // desktop mobile supporter, // chrome safari firefox opera iexplore edge supporterVs, system, // windows macos linux android ios systemVs }, shell === "none" ? {} : { shell, // wechat qq uc 360 2345 sougou liebao maxthon shellVs });}在控制台执行BrowserType(),该有的都出来了,哈哈!源码详情请戳这里,喜欢的可以点个赞支持下,谢谢 。

文章插图
结语写到最后总结得差不多了,后续如果我想起还有哪些判断浏览器运行环境终极方案遗漏的,会继续在这篇文章上补全,同时也希望各位朋友对文章里的要点进行补充或者提出自己的见解 。欢迎在下方进行评论或补充喔,喜欢的点个赞或收个藏,保证你在开发时用得上 。
关注公众号Uzero,更多前端小干货等着你喔!我是JowayYoung,喜欢分享前端技术和生活纪事,学习与生活不落下,每天进步一点点,与大家相伴成长
【详细判断浏览器运行环境】
推荐阅读
-
-
詹秋怡跟宠物玩耍,失去了《offer2》滤镜,这颜值我没眼花吧?
-
妈妈说,无论你结不结婚,这五种状态都是女人应该有的样子
-
婚恋|75岁独居老人去世后,50岁保姆拿着结婚证和老人子女争财产。
-
[婚姻]42岁女子背叛婚姻,却拿爱情当幌子,请记住“婚外关系”不是爱情
-
【蝗玩军团】总有一套适合你!,奇迹暖暖:金牛月来了!这几套不同风格的穿搭
-
-
理想或在2022年发布纯电车型 有望搭载400V超充
-
-
长长严选■网友:两人都好看,吴宣仪又“撞衫”了?同款刘雯穿成“大女人”
-
朴永训|花开三朵!国手山脉杯,朴永训九段连夺两届冠军?
-
-
-
范和身边好|庐江县举办2020年“新时代好少年”先进事迹发布仪式
-
-
DNF|DNF:红白双神视角下,大恍惚的强度如何?剑魂哥直接幻神
-
小娱乐观光:为啥能恪尽职守十多年,内行人透露了真相,加油站员工月薪仅2000
-
网上车市|S63有望采用插混动力 或3s破百 最快的D级车来了?,新一代奔驰AMG
-
-
[美联储]原油跌至“冰点”,中国该“抢”油了,然而石油进口量却在下降?