浏览器怎么显示javascript页面(JavaScript如何通过userAgent判断几个常用浏览器详解)
浏览器怎么显示javascript页面
JavaScript如何通过userAgent判断几个常用浏览器详解前言
通常在做h5页面的时候需要在微信、QQ、微博等生态内做一些引流的工作,但引流时受限于这些平台。比如上次的文章《h5唤醒app实现以及注意点》就是妥协的一个办法,那么常用的这几个浏览器的User Agent什么样呢?如何判断呢?今天就具体来看看这个问题。
User Agent定义
User Agent中文名为用户代理,简称 UA,它是一个特殊字符串头,使得服务器能够识别客户使用的操作系统及版本、CPU 类型、浏览器及版本、浏览器渲染引擎、浏览器语言、浏览器插件等。---来自百度百科
从这句话可以知道我们通过UA能获取到用户使用的操作系统以及版本、cpu类型、浏览器以及版本等信息,是不是呢?
常见的几个浏览器UA
这里仅仅获取了微信、微博、QQ几个浏览器,其余的目前未获取,如果大家有补充的请私信或则定下评论哦。
安卓
安卓端的目前采用的是华为Honor V9 Play,当前Android系统版本为7.0,EMUI版本为5.1。
QQ浏览器
- UA:mozilla/5.0 (linux; u; android 7.0; zh-cn; jmm-al10 build/honorjmm-al10) applewebkit/537.36 (khtml, like gecko) version/4.0 chrome/66.0.3359.126 mqqbrowser/9.6 mobile safari/537.36
- Version:9.6.0.5170
- UA:mozilla/5.0 (linux; android 7.0; jmm-al10 build/honorjmm-al10; wv) applewebkit/537.36 (khtml, like gecko) version/4.0 chrome/62.0.3202.84 mobile safari/537.36 v1_and_sq_8.1.0_1232_yyb_d qq/8.1.0.4150 nettype/wifi webp/0.4.1 pixel/720 statusbarheight/49 simpleuiswitch/0
- Version:8.1.0.4150
微信
- UA:mozilla/5.0 (linux; android 7.0; jmm-al10 build/honorjmm-al10; wv) applewebkit/537.36 (khtml, like gecko) version/4.0 chrome/66.0.3359.126 mqqbrowser/6.2 tbs/044807 mobile safari/537.36 mmwebid/4093 micromessenger/7.0.6.1460(0x27000634) process/tools nettype/wifi language/zh_cn
- Version:7.0.6
微博
- UA:mozilla/5.0 (linux; android 7.0; jmm-al10 build/honorjmm-al10; wv) applewebkit/537.36 (khtml, like gecko) version/4.0 chrome/62.0.3202.84 mobile safari/537.36 weibo (huawei-jmm-al10__weibo__9.8.0__android__android7.0)
- Version:9.8.0
苹果
苹果端的目前采用的是iPhone 6s Plus,当前iOS版本为12.4。
QQ浏览器
- UA:mozilla/5.0 (iphone; cpu iphone os 12_4 like mac os x) applewebkit/605.1.15 (khtml, like gecko) version/12.0 mqqbrowser/9.6.0 mobile/15e148 safari/604.1 qbwebviewua/2 qbwebviewtype/1 wktype/1
- Version:9.6.0.4193
- UA:mozilla/5.0 (iphone; cpu iphone os 12_4 like mac os x) applewebkit/605.1.15 (khtml, like gecko) mobile/15e148 qq/8.1.0.437 v1_iph_sq_8.1.0_1_app_a pixel/1080 core/wkwebview device/apple(iphone 6splus) nettype/wifi qbwebviewtype/1 wktype/1
- Version:8.1.0.437
微信
- UA:mozilla/5.0 (iphone; cpu iphone os 12_4 like mac os x) applewebkit/605.1.15 (khtml, like gecko) mobile/15e148 micromessenger/7.0.5(0x17000523) nettype/wifi language/zh_cn
- Version:7.0.5
微博
- UA:mozilla/5.0 (iphone; cpu iphone os 12_4 like mac os x) applewebkit/605.1.15 (khtml, like gecko) mobile/15e148 weibo (iphone8,2__weibo__9.7.1__iphone__os12.4)
- Version:9.7.1
以上UA的所有值都通过toLowerCase处理,所以都是小写的。
分别判断几个常用浏览器
在判断之前需要对UA做一个操作就是将所有的字母都变成小写的,通过toLowerCase实现,然后分别来判断。
通过上面的几个UA其实已经很好判断了,在上次的文章里面已经有个这个写法了,如下:
/micromessenger/i.test(u) // 判断微信 u.indexOf("weibo") > -1 // 判断微博 u.indexOf(" qq") > -1 // 判断QQ u.indexOf("mqqbrowser") > -1 // 判断QQ浏览器
注意QQ的判断是需要在qq前面加空格的
获取其它信息
通过上面的UA其实不难看出还可以通过UA判断出当前是系统是Android还是iOS,可以通过以下代码来区分:
/android/i.test(UA) // 判断Android /(iPhone|iPad|iPod|iOS)/i.test(UA) // 判断iOS
通过上面的数据还可以看出手机的具体类型,这里就不过多介绍了。另外很多移动端浏览器是可以改变UA的,比如夸克和UC。如果大家深入研究还能获取到更多的信息的。
总结
到此这篇关于JavaScript如何通过userAgent判断几个常用浏览器的文章就介绍到这了,更多相关JS userAgent判断浏览器内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
- extjs 日期控件
- js RegExp用法
- js如何将json字符串转换为json对象
- js Date对象
- python获取json结果保存文本(Python JSON格式数据的提取和保存的实现)
- js常见面试题
- js的事件处理程序底层原理(关于js的事件循环机制剖析)
- jscanvas背景色(JavaScript canvas实现代码雨效果)
- extjs多选下拉框
- 用js编写tab栏切换(JavaScript实现简易tab栏切换内容栏)
- nodejssocket文件传输(node+socket实现简易聊天室功能)
- js怎么上传压缩图片(如何用JS有效的压缩图片)
- Extjs menu菜单的简单用法
- angularjs使用指令(详解Angular路由动画及高阶动画函数)
- js闭包可以解决哪些问题(JavaScript中let避免闭包造成问题)
- 最全js面试题(JavaScript必看的10道面试题总结推荐)
- 岳云鹏不说相声,改行演员了 网友 快回来说相声(岳云鹏不说相声)
- 乔欣首演古装大女主,颜值演技双在线(乔欣首演古装大女主)
- 于正又推女性古装大剧 杨蓉乔欣演女配,两位女主成 重头戏(于正又推女性古装大剧)
- 乔欣古装女主戏获热度 作为女主,却没吃到红利(乔欣古装女主戏获热度)
- 爱情是什么(爱情是什么最经典的话)
- 乔欣 古装剧中的高颜值(古装剧中的高颜值)
热门推荐
- 用python做一个表白视频(python仿抖音表白神器)
- 数据推入阿里云rds(将阿里云RDS中的数据库迁移到本机自建数据库的可用过程RDS数据迁移)
- sql语句行转列怎么设置(SQL行转列和列转行代码详解)
- mysql 死锁查询(MySQL slave 延迟一列 外键检查和自增加锁)
- mysql触发器怎么添加(MySQL触发器的使用场景及方法实例)
- 如何使用python定时运行(Python实现定时执行任务的三种方式简单示例)
- try...catch... finally 的用法
- 如何查看mysql执行计划(到底什么是Mysql执行计划?)
- datatable添加行列
- dedecms栏目静态化(DedeCms获取任意栏目N级列表链接树形菜单的方法)