用indexOf判断设备
通过userAgent去判断,先判断是否为移动端,可以判断是iOS终端和Android终端,也可以具体到应用进行判断微信,微博,qq访问。
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>用indexof判断设备</title>
</head>
<body>
<a href="javascript:;" id="J_checkplatformbtn">用indexOf判断设备</a><script>
window.onload=function(){
var browser = {
versions: function() {
var u = navigator.userAgent,
ua = navigator.userAgent.toLowerCase();
return {
//内核,比如ie,firefox,chrome,opera,苹果
trident: u.indexOf('Trident') > -1, //IE内核
gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核
webkit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
presto: u.indexOf('Presto') > -1, //opera内核
//终端,操作系统,比如PC端,os,移动端,ios,android
mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或uc浏览器
//设备,比如iphone,ipad
iphone: u.indexOf('iPhone') > -1, //是否为iPhone或者QQHD浏览器
ipad: u.indexOf('iPad') > -1, //是否iPad
//应用程序,比如Safari浏览器,UC浏览器,微信,微博,QQ
webapp: u.indexOf('Safari') == -1, //是否web应用程序,没有头部与底部
wechat: ua.match(/MicroMessenger/i) == "micromessenger", //微信
weibo: ua.match(/WeiBo/i) == "weibo", //微博
qq: ua.match(/QQ/i) == "qq" //qq
};
}(),
language: (navigator.browserLanguage || navigator.language).toLowerCase() //检测浏览器语言
};
//检查设备, mainFun
function checkDevice(){
if (browser.versions.mobile) {
//在移动端浏览器打开
if (browser.versions.ios) {
//在IOS浏览器打开
alert('ios操作系统'+ navigator.userAgent);
}if (browser.versions.android) {
//在安卓浏览器打开
alert('android操作系统'+ navigator.userAgent);
}if (browser.versions.iphone) {
//在iphone中打开
alert('iphone设备'+ navigator.userAgent);
}if (browser.versions.ipad) {
//在ipad中打开
alert('ipad设备'+ navigator.userAgent);
}if (browser.versions.webapp) {
//在webapp中打开
alert('webapp应用程序'+ navigator.userAgent);
}if (browser.versions.wechat) {
//在微信中打开
alert('wechat应用程序'+ navigator.userAgent);
}if (browser.versions.weibo) {
//在新浪微博客户端打开
alert('weibo应用程序'+ navigator.userAgent);
}if (browser.versions.qq) {
//在QQ空间打开
alert('qq应用程序'+ navigator.userAgent);
}
}
else {
//在PC端浏览器打开
if (browser.versions.trident) {
//在IE浏览器打开
alert('在IE浏览器打开'+ navigator.userAgent);
}if (browser.versions.gecko) {
//在火狐浏览器打开
alert('在火狐浏览器打开'+ navigator.userAgent);
}if (browser.versions.webkit) {
//在苹果、谷歌浏览器打开
alert('在苹果、谷歌浏览器打开'+ navigator.userAgent);
}if (browser.versions.presto) {
//在opera浏览器打开
alert('在opera浏览器打开'+ navigator.userAgent);
}
}
};
function addEvent(obj,type,handle){
try{ // Chrome、FireFox、Opera、Safari、IE9.0及其以上版本
obj.addEventListener(type,handle,false);
}catch(e){
try{ // IE8.0及其以下版本
obj.attachEvent('on' + type,handle);
}catch(e){ // 早期浏览器
obj['on' + type] = handle;
}
}
}
//这里使用 try{ ... } catch(e){ ... } 代替 if ... else... 语句,避免浏览器出现错误提示。
var triggerbtn=document.getElementById('J_checkplatformbtn');
addEvent(triggerbtn,'click',checkDevice);
}
</script>
</body>
</html>
用indexOf判断设备的更多相关文章
- 用indexOf判断设备是否是PC端?
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- js判断设备,跳转app应用、android市场或者AppStore
js移动设备判断方法大全 <!DOCTYPE html> <html> <head> <meta charset="UTF-8" > ...
- js检查判断设备
js检查判断设备 var navigatorType = {}; var u=navigator.userAgent; navigatorType.IsIE= u.indexOf('Trident') ...
- IOS判断设备是否已越狱
转自:http://www.cnblogs.com/supercheng/archive/2012/12/05/2804166.html - (BOOL)isJailbroken { BOOL jai ...
- JS判断设备终端(PC,iPad,iPhone,android,winPhone)和浏览器
JS判断设备终端(PC,iPad,iPhone,android,winPhone)和浏览器 var ua = navigator.userAgent; var browser = {}, weixin ...
- 判断iPhone和iPad 判断设备版本
//判断iPhone和iPad #define IS_IPHONE (!IS_IPAD) #define IS_IPAD (UI_USER_INTERFACE_IDIOM() != UIUserInt ...
- 调用[[UIDevice currentDevice] userInterfaceIdiom]==UIUserInterfaceIdiomPad判断设备
将模拟器改为Ipad时,调用[[UIDevice currentDevice] userInterfaceIdiom]==UIUserInterfaceIdiomPad判断设备是否为Ipad,但程序并 ...
- (原) Jquery 判断设备是PC端,还是移动端
判断设备是PC端,还是移动端 var ua = navigator.userAgent.toLocaleLowerCase(); var pf = navigator.platform.toLocal ...
- Android之判断设备网络连接状态,并判断连接方式
在Android开发过程中,对于一个需要连接网络的Android设备,对设备的网络状态检测是很有必要的!有很多的App都需要连接网络.判断设备是否已经连接网络,并且在连接网络的状态下判断是wifi无线 ...
随机推荐
- zhx's contest (矩阵快速幂 + 数学推论)
zhx's contest Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) To ...
- Truck History(prim & mst)
Truck History Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 19772 Accepted: 7633 De ...
- linux shell 流程控制
导读 和Java.PHP等语言不一样,linux shell有一套自己的流程控制语句,其中包括条件语句(if),循环语句(for,while),选择语句(case).下面我将通过例子介绍下,各个语句使 ...
- 入侵检测课设之Libnids开发包
Libnids开发包介绍 Libnids是一个用于网络入侵检测开发的专业编程接口,它使用了Libpcap所以它具有捕获数据包的功能.同时,Libnids提供了TCP数据流重组功能,所以对于分析 ...
- 【UER #1】[UOJ#12]猜数 [UOJ#13]跳蚤OS [UOJ#14]DZY Loves Graph
[UOJ#12][UER #1]猜数 试题描述 这一天,小Y.小D.小C正在愉快地玩耍. 小Y是个数学家,他一拍脑袋冒出了一个神奇的完全平方数 n. 小D是个机灵鬼,很快从小Y嘴里套出了 n的值.然后 ...
- 暑假热身 A. GCC
GCC编译器是一个由GNU项目维护的编译系统,它支持多种编程语言的编译.但是它并不包含数学运算符“!”.在数学中,这个符号代表阶乘.表达式n!的意思是从1到n的所有整数的乘积. 例如,4!=4*3*2 ...
- (int),Int32.Parse() 和 Convert.toInt32() 的区别
在 C# 中,(int),Int32.Parse() 和 Convert.toInt32() 三种方法有何区别? int 关键字表示一种整型,是32位的,它的 .NET Framework 类型为 S ...
- 面向侧面的程序设计AOP-------《三》.Net平台AOP技术概览
本文转载自张逸:晴窗笔记 .Net平台与Java平台相比,由于它至今在服务端仍不具备与unix系统的兼容性,也不具备类似于Java平台下J2EE这样的企业级容器,使得.Net平台在大型的企业级应用上, ...
- Nested List Weight Sum I & II
Nested List Weight Sum I Given a nested list of integers, return the sum of all integers in the list ...
- 用cocos2dx实现模态对话框
ui部分使用了cocoStudio,注意这里没有实现怎么屏蔽其他的输入事件,其他的文档已经太多了,我这里使用的cocoStudio的控件自己的特性. 这里强烈推荐一下cocoStudio,虽然现在还有 ...