JS判断客户端是手机还是PC的2个代码


Posted in Javascript onApril 12, 2014

1、第一种:

function IsPC() {
  var userAgentInfo = navigator.userAgent;
  var Agents = ["Android", "iPhone",
        "SymbianOS", "Windows Phone",
        "iPad", "iPod"];
  var flag = true;
  for (var v = 0; v < Agents.length; v++) {
    if (userAgentInfo.indexOf(Agents[v]) > 0) {
      flag = false;
      break;
    }
  }
  return flag;
}

2、第二种:

function browserRedirect() {
  var sUserAgent = navigator.userAgent.toLowerCase();
  var bIsIpad = sUserAgent.match(/ipad/i) == "ipad";
  var bIsIphoneOs = sUserAgent.match(/iphone os/i) == "iphone os";
  var bIsMidp = sUserAgent.match(/midp/i) == "midp";
  var bIsUc7 = sUserAgent.match(/rv:1.2.3.4/i) == "rv:1.2.3.4";
  var bIsUc = sUserAgent.match(/ucweb/i) == "ucweb";
  var bIsAndroid = sUserAgent.match(/android/i) == "android";
  var bIsCE = sUserAgent.match(/windows ce/i) == "windows ce";
  var bIsWM = sUserAgent.match(/windows mobile/i) == "windows mobile";
  if (!(bIsIpad || bIsIphoneOs || bIsMidp || bIsUc7 || bIsUc || bIsAndroid || bIsCE || bIsWM) ){
    window.location.href=B页面;
  }
}
browserRedirect();

百度的判断代码

function uaredirect(f) {
 try {
 if (document.getElementById("bdmark") != null) {
  return
 }
 var b = false;
 if (arguments[1]) {
  var e = window.location.host;
  var a = window.location.href;
  if (isSubdomain(arguments[1], e) == 1) {
  f = f + "/#m/" + a;
  b = true
  } else {
  if (isSubdomain(arguments[1], e) == 2) {
   f = f + "/#m/" + a;
   b = true
  } else {
   f = a;
   b = false
  }
  }
 } else {
  b = true
 }
 if (b) {
  var c = window.location.hash;
  if (!c.match("fromapp")) {
  if ((navigator.userAgent.match(/(iPhone|iPod|Android|ios|SymbianOS)/i))) {
   location.replace(f)
  }
  }
 }
 } catch(d) {}
}
function isSubdomain(c, d) {
 this.getdomain = function(f) {
 var e = f.indexOf("://");
 if (e > 0) {
  var h = f.substr(e + 3)
 } else {
  var h = f
 }
 var g = /^www\./;
 if (g.test(h)) {
  h = h.substr(4)
 }
 return h
 };
 if (c == d) {
 return 1
 } else {
 var c = this.getdomain(c);
 var b = this.getdomain(d);
 if (c == b) {
  return 1
 } else {
  c = c.replace(".", "\\.");
  var a = new RegExp("\\." + c + "$");
  if (b.match(a)) {
  return 2
  } else {
  return 0
  }
 }
 }
};

使用方法:
<SCRIPT type=text/javascript>uaredirect("手机站","WEB站");</SCRIPT>

另外一篇,感觉不如上面的好,不过大家可以参考下

var browser_class = navigator.userAgent;
var browser_class_name1 = browser_class.match("Mobile");
var browser_class_name2 = browser_class.match("mobile");
var location_url = window.location.href;
if (browser_class_name1 != null || browser_class_name2 != null) {
 if (location_url.match("wap") == null) {
 window.location.href = "http://wap.xxxx.com";
 }
} else {
 if (location_url.match("3g") != null || location_url.match("wap") != null) {
 window.location.href = "http://wap.xxxx.com";
 }
}

这篇文章就介绍到这了,具体的也可以参考下面的文章。

Javascript 相关文章推荐
070823更新的一个[消息提示框]组件 兼容ie7
Aug 29 Javascript
基于jQuery的仿flash的广告轮播代码
Nov 04 Javascript
javascript实现的闭包简单实例
Jul 17 Javascript
Bootstrap3学习笔记(三)之表格
May 20 Javascript
AngularJS入门教程之过滤器详解
Aug 19 Javascript
AngularJS中ng-class用法实例分析
Jul 06 Javascript
Vue不能检测到Object/Array更新的情况的解决
Jun 26 Javascript
vue里面使用mui的弹出日期选择插件实例
Sep 16 Javascript
JS多个异步请求 按顺序执行next实现解析
Sep 16 Javascript
为nuxt项目写一个面包屑cli工具实现自动生成页面与面包屑配置
Sep 29 Javascript
微信小程序保存图片到相册权限设置
Apr 09 Javascript
javascript之Object.assign()的痛点分析
Mar 03 Javascript
javascript window.open打开新窗口后无法再次打开该窗口问题的解决方法
Apr 12 #Javascript
jQuery中阻止冒泡事件的方法介绍
Apr 12 #Javascript
jquery ajax应用中iframe自适应高度问题解决方法
Apr 12 #Javascript
javascript事件冒泡详解和捕获、阻止方法
Apr 12 #Javascript
一个非常全面的javascript URL解析函数和分段URL解析方法
Apr 12 #Javascript
用jquery写的菜单从左往右滑动出现
Apr 11 #Javascript
瀑布流布局代码一例
Apr 11 #Javascript
You might like
地球防卫队:陪着奥特曼打小怪兽的人类力量 那些经典队服
2020/03/08 日漫
深入phpMyAdmin的安装与配置的详细步骤
2013/05/07 PHP
解析如何去掉CodeIgniter URL中的index.php
2013/06/25 PHP
PHP使用适合阅读的格式显示文件大小的方法
2015/03/05 PHP
PHP图形操作之Jpgraph学习笔记
2015/12/25 PHP
javascript:history.go()和History.back()的区别及应用
2012/11/25 Javascript
详解javascript的变量与标识符
2016/01/04 Javascript
使用angularjs创建简单表格
2016/01/21 Javascript
javascript实现下雪效果【实例代码】
2016/05/03 Javascript
详解AngularJS中的表单验证(推荐)
2016/11/17 Javascript
Bootstrap实现导航栏的2种方式
2016/11/28 Javascript
jquery利用json实现页面之间传值的实例解析
2016/12/12 Javascript
微信小程序 template模板详解及实例
2017/02/21 Javascript
php输出全部gb2312编码内的汉字方法
2017/03/04 Javascript
Vue组件通信实践记录(推荐)
2017/08/15 Javascript
JS和JQuery实现雪花飘落效果
2017/11/30 jQuery
Vue结合后台导入导出Excel问题详解
2019/02/19 Javascript
记一次vue跨域的解决
2020/10/21 Javascript
[46:12]完美世界DOTA2联赛循环赛 DM vs Matador BO2第一场 11.04
2020/11/04 DOTA
python中关于时间和日期函数的常用计算总结(time和datatime)
2013/03/08 Python
Python使用迭代器打印螺旋矩阵的思路及代码示例
2016/07/02 Python
使用Python从有道词典网页获取单词翻译
2016/07/03 Python
Python微医挂号网医生数据抓取
2019/01/24 Python
python实现对图片进行旋转,放缩,裁剪的功能
2019/08/07 Python
Python三元运算与lambda表达式实例解析
2019/11/30 Python
python GUI库图形界面开发之PyQt5窗口控件QWidget详细使用方法
2020/02/26 Python
Python图像处理之膨胀与腐蚀的操作
2021/02/07 Python
HTML5中判断用户是否正在浏览页面的方法
2014/05/03 HTML / CSS
英国创新设计文具、卡片和礼品包装网站:Paperchase
2018/07/14 全球购物
后勤岗位职责
2013/11/26 职场文书
搞笑创意广告语
2014/03/17 职场文书
2014年售后服务工作总结
2014/11/18 职场文书
一年级小学生评语大全
2014/12/25 职场文书
2021年最新用于图像处理的Python库总结
2021/06/15 Python
Mysql 如何合理地统计一个数据库里的所有表的数据量
2022/04/18 MySQL
JS前端可扩展的低代码UI框架Sunmao使用详解
2022/07/23 Javascript