js获取设备
总结了一个JavaScript获取当前终端类型(pc, mobile),操作系统类型,浏览器类型,浏览器版本的小工具。
个人觉得还行,测试过没有问题,能识别ie7以及以上。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
/** author: Weihuan date: 2017-6-26 **/ var _AgentInfo = { deviceType: "" , // pc or mobile OSname: "" , // windows, Android, linux and so on... browserName: "" , // chrome, safari, firefox, IE and so on... browserVer: "" , // browser version, important if in IE environment. adaptType: 0, // A type value, Adapt to the screen due to width _init: function (){ _AgentInfo.setDeviceAndOS(); _AgentInfo.setBrowser(); }, setDeviceAndOS: function (){ var name = "unknown" ; if (window.navigator.userAgent.indexOf( "Android" ) != -1){ name = "Android" ; } else if (window.navigator.userAgent.indexOf( "iPhone" ) != -1){ name = "iPhone" ; } else if (window.navigator.userAgent.indexOf( "SymbianOS" ) != -1){ name = "SymbianOS" ; } else if (window.navigator.userAgent.indexOf( "Windows Phone" ) != -1){ name = "Windows Phone" ; } else if (window.navigator.userAgent.indexOf( "iPad" ) != -1){ name = "iPad" ; } else if (window.navigator.userAgent.indexOf( "iPod" ) != -1){ name = "iPod" ; } if (name != "unknown" ){ _AgentInfo.OSname = name; _AgentInfo.deviceType = "mobile" ; return ; } if (window.navigator.userAgent.indexOf( "Windows NT 10.0" )!= -1){ name= "Windows 10" ; } else if (window.navigator.userAgent.indexOf( "Windows NT 6.2" ) != -1){ name= "Windows 8" ; } else if (window.navigator.userAgent.indexOf( "Windows NT 6.1" ) != -1){ name= "Windows 7" ; } else if (window.navigator.userAgent.indexOf( "Windows NT 6.0" ) != -1){ name= "Windows Vista" ; } else if (window.navigator.userAgent.indexOf( "Windows NT 5.1" ) != -1){ name= "Windows XP" ; } else if (window.navigator.userAgent.indexOf( "Windows NT 5.0" ) != -1){ name= "Windows 2000" ; } else if (window.navigator.userAgent.indexOf( "Mac" ) != -1){ name= "Mac/iOS" ; } else if (window.navigator.userAgent.indexOf( "X11" ) != -1){ name= "UNIX" ; } else if (window.navigator.userAgent.indexOf( "Linux" ) != -1){ name= "Linux" ; } _AgentInfo.OSname = name; _AgentInfo.deviceType = "pc" ; }, setBrowser: function (){ var nAgt = navigator.userAgent; var browserName = navigator.appName; var fullVersion = '' +parseFloat(navigator.appVersion); var majorVersion = parseInt(navigator.appVersion,10); var nameOffset,verOffset,ix; if ((verOffset=nAgt.indexOf( "Opera" ))!=-1) { // In Opera, the true version is after "Opera" or after "Version" browserName = "Opera" ; fullVersion = nAgt.substring(verOffset+6); if ((verOffset=nAgt.indexOf( "Version" ))!=-1) fullVersion = nAgt.substring(verOffset+8); } else if ( (nAgt.indexOf( "Trident" ))!=-1 ) { // ( ver >= ie7) In MSIE, the true version is after "MSIE" in userAgent if ((verOffset=nAgt.indexOf( "MSIE" ))!=-1){ fullVersion = nAgt.substring(verOffset+5); } else { fullVersion = '11.0' ; } if (fullVersion == 5){ fullVersion = "11.0" ; } browserName = "IE" ; } else if ((verOffset=nAgt.indexOf( "Chrome" ))!=-1) { // In Chrome, the true version is after "Chrome" browserName = "Chrome" ; fullVersion = nAgt.substring(verOffset+7); } else if ((verOffset=nAgt.indexOf( "Safari" ))!=-1) { // In Safari, the true version is after "Safari" or after "Version" browserName = "Safari" ; fullVersion = nAgt.substring(verOffset+7); if ((verOffset=nAgt.indexOf( "Version" ))!=-1) fullVersion = nAgt.substring(verOffset+8); } else if ((verOffset=nAgt.indexOf( "Firefox" ))!=-1) { // In Firefox, the true version is after "Firefox" browserName = "Firefox" ; fullVersion = nAgt.substring(verOffset+8); } else if ( (nameOffset=nAgt.lastIndexOf( ' ' )+1) < (verOffset=nAgt.lastIndexOf( '/' )) ){ // In most other browsers, "name/version" is at the end of userAgent browserName = nAgt.substring(nameOffset,verOffset); fullVersion = nAgt.substring(verOffset+1); if (browserName.toLowerCase()==browserName.toUpperCase()) { browserName = navigator.appName; } } if ((ix=fullVersion.indexOf( ";" ))!=-1) // trim the fullVersion string at semicolon/space if present fullVersion=fullVersion.substring(0,ix); if ((ix=fullVersion.indexOf( " " ))!=-1) fullVersion=fullVersion.substring(0,ix); majorVersion = parseInt( '' +fullVersion,10); if (isNaN(majorVersion)) { fullVersion = '' +parseFloat(navigator.appVersion); majorVersion = parseInt(navigator.appVersion,10); } _AgentInfo.browserName = browserName; _AgentInfo.browserVer = fullVersion; }, isMobile: function (){ if (_AgentInfo.deviceType == "mobile" ){ return true ; } return false ; }, setAdaptType(){ // A type value, Adapt to the screen due to width. For convenient if (screen.width <= 374){ _AgentInfo.adaptType = 0; } else if (screen.width <= 413){ _AgentInfo.adaptType = 1; } else { _AgentInfo.adaptType = 2; } } } |
js获取设备的更多相关文章
- 每日技术总结:vue router传参方式,js获取设备高度
今天貌似没什么问题,23333…… 1.vue router 路由传参的方式 应用情景:从分类页(category.vue)进入商品列表页(list.vue),需要传递商品分类id(catId),商品 ...
- js获取设备公网ip + 服务器根据公网ip 获取IP信息
1.前言 本来呢,想实现js定位功能,最少定位到城市,一开始,使用的是搜狐的api直接获取数据,可是,有时候搜狐不可靠,只能得到 公网ip,其他信息无用,就像这样 2.既然这样,还不如我自己请求自己的 ...
- js获取设备内网ip
可以直接使用,不需要导入其他配置 看代码 1 <script> 2 //获取内网ip 3 var RTCPeerConnection = window.RTCPeerConnection ...
- js获取设备信息
var su = navigator.userAgent.toLowerCase(), mb = ['ipad', 'iphone os', 'midp', 'rv:1.2.3.4', 'ucweb' ...
- php获取设备的宽度和高度
php获取设备的宽度和高度 如果前台没有传输当前请求的宽度和高度,我们有时候需要用php借助javascript获取屏幕的宽和高,以控制现实的样式. 代码如下: <?php /* * 获取设备宽 ...
- js获取屏幕(设备)宽高
平常获取设备的宽高无非就那几 <script language="javascript"> var h = ""; h += " 网页可见 ...
- js获取url参数值(HTML之间传值)
<h3>未设置设备: <a href="javascript:addTab('设备列表','PKE_DeviceContent/PKE_DeviceContent.aspx ...
- Cordova各个插件使用介绍系列(六)—$cordovaDevice获取设备的相关信息
详情请看:Cordova各个插件使用介绍系列(六)—$cordovaDevice获取设备的相关信息 在项目中需要获取到当前设备,例如手机的ID,联网状态,等,然后这个Cordova里有这个插件可以用, ...
- 获取设备IP地址
腾讯的IP地址API接口地址:http://fw.qq.com/ipaddress返回的是数据格式为: 1 var IPData = new Array(“58.218.198.205″,”" ...
随机推荐
- JavaScript(第二十三天)【事件入门】
JavaScript事件是由访问Web页面的用户引起的一系列操作,例如:用户点击.当用户执行某些操作的时候,再去执行一系列代码. 一.事件介绍 事件一般是用于浏览器和用户操作进行交互.最早是IE和 ...
- php 常用数据大全
一.数组操作的基本函数 数组的键名和值 array_values($arr);获得数组的值 array_keys($arr);获得数组的键名 array_flip($arr);数组中的值与键名互换(如 ...
- 云计算之路-阿里云上-容器难容:优化自建 docker swarm 集群的部署
在上周六遭遇阿里云容器服务 swarm 版的故障之后,我们决定还是走自建 docker swarm 之路,只要不是阿里云底层的问题,我们相信会找到办法解决或避开自建 docker swarm 不稳定的 ...
- 数据结构——线性表——队列(queue)
队列也是一种特殊的线性表,它的特点是先入先出(FIFO,即first in first out).它的意思也很直观,想象一下排队买票,先排的人先买(插队是不对的,所以别去想).它也是很常用的数据结构, ...
- 201621123031 《Java程序设计》第9周学习总结
作业09-集合与泛型 1.本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结集合与泛型相关内容. 一.泛型的基本概念 泛型是JDK 1.5的一项新特性,它的本质是参数化类型(Paramet ...
- 201621123068 《Java程序设计》第1周学习总结
1. 本周学习总结 本周学习了如何使用Java来编写程序,还没展开学习具体的语言,但是也花了大量的时间搞清楚Java运行的原理.明白了Java是一种可以跨平台运行语言,搞清了jdk,jre,jvm之间 ...
- JSONP 详解
1.什么是JSONP ? JSONP(JSON with Padding)是一个非官方的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实 ...
- nyoj 背包问题
背包问题 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 现在有很多物品(它们是可以分割的),我们知道它们每个物品的单位重量的价值v和重量w(1<=v,w< ...
- Win7下安装composer, 并使用其安装smarty
安装composer需要开启PHP openssl扩展. 1) 先查看PHP是否开启了openssl扩展 键盘win+r 输出cmd, 可以看到Dos窗口, 然后执行php -m (需要添加PHP环境 ...
- C语言头文件引用
1,引用分为两种 firs:include<fileName.h> 引用系统头文件一般用<>. second:include"fileName.h" 引用自 ...