JS判断当前页面是否在微信浏览器打开的方法


Posted in Javascript onDecember 08, 2015

本文实例讲述了JS判断当前页面是否在微信浏览器打开的方法。分享给大家供大家参考,具体如下:

最近做很多HTML5的项目,很多页面会通过微信微博等SNS分享出去。在分享页面上提供公司APP的下载。但是在很多应用的浏览器中,点击下载链接无法下载应用。那么针对这些浏览器我们需要给用户提示从safari或者系统自带的浏览器打开分享页面。通过js就可以判断当前页面是在什么浏览器打开的。

以下是一段示例代码,注释中表明了通过JS如何判断是否在微信浏览器打开,是否在QQ空间浏览器,是否在新浪微博打开。当然可以做得更完善一点,再加上判断是在移动设备打开还是在PC端浏览器打开的,更加细分一点,可以判断是在安卓系统的浏览器打开的还是IOS系统浏览器打开的。

if (browser.versions.mobile) {//判断是否是移动设备打开。browser代码在下面
  var ua = navigator.userAgent.toLowerCase();//获取判断用的对象
  if (ua.match(/MicroMessenger/i) == "micromessenger") {
    //在微信中打开
  }
  if (ua.match(/WeiBo/i) == "weibo") {
    //在新浪微博客户端打开
  }
  if (ua.match(/QQ/i) == "qq") {
    //在QQ空间打开
  }
  if (browser.versions.ios) {
    //是否在IOS浏览器打开
  } 
  if(browser.versions.android){
    //是否在安卓浏览器打开
  }
} else {
  //否则就是PC浏览器打开
}

再附上browser的代码,通过以下方法可以判断很多浏览器。包括判断IE浏览器,Opera浏览器,苹果浏览器,谷歌浏览器,火狐浏览器等。

var browser = {
 versions: function () {
  var u = navigator.userAgent, app = navigator.appVersion;
  return {   //移动终端浏览器版本信息
   trident: u.indexOf('Trident') > -1, //IE内核
   presto: u.indexOf('Presto') > -1, //opera内核
   webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
   gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核
   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: u.indexOf('iPhone') > -1, //是否为iPhone或者QQHD浏览器
   iPad: u.indexOf('iPad') > -1, //是否iPad
   webApp: u.indexOf('Safari') == -1 //是否web应该程序,没有头部与底部
  };
 }(),
 language: (navigator.browserLanguage || navigator.language).toLowerCase()
}

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
一个简单的jQuery插件ajaxfileupload.js实现ajax上传文件例子
Jun 26 Javascript
实例详解jQuery Mockjax 插件模拟 Ajax 请求
Jan 12 Javascript
如何理解jQuery中的ajaxSubmit方法
Mar 13 Javascript
强大的 Angular 表单验证功能详细介绍
May 23 Javascript
JavaScript字符串_动力节点Java学院整理
Jun 27 Javascript
利用Javascript开发一个二维周视图日历
Dec 14 Javascript
Webpack的dll功能使用
Jun 28 Javascript
微信小程序日历/日期选择插件使用方法详解
Dec 28 Javascript
微信小程序发送短信验证码完整实例
Jan 07 Javascript
微信小程序如何自定义table组件
Jun 29 Javascript
vue中实现弹出层动画效果的示例代码
Sep 25 Javascript
多种类型jQuery网页验证码插件代码实例
Jan 09 jQuery
js实现兼容IE、Firefox的图片缩放代码
Dec 08 #Javascript
JS实现按比例缩放图片的方法(附C#版代码)
Dec 08 #Javascript
JS获取文件大小方法小结
Dec 08 #Javascript
js+ajax实现获取文件大小的方法
Dec 08 #Javascript
JS表格组件神器bootstrap table详解(基础版)
Dec 08 #Javascript
详解js中构造流程图的核心技术JsPlumb(2)
Dec 08 #Javascript
详解js中构造流程图的核心技术JsPlumb
Dec 08 #Javascript
You might like
PHP随机字符串生成代码(包括大小写字母)
2013/06/24 PHP
深入PHP购物车模块功能分析(函数讲解,附源码)
2013/06/25 PHP
php限制ip地址范围的方法
2015/03/31 PHP
php post换行的方法
2020/02/03 PHP
javascript实现轮显新闻标题链接
2007/08/13 Javascript
基于Jquery的文字滚动跑马灯插件(一个页面多个滚动区)
2010/07/26 Javascript
jquery动画2.元素坐标动画效果(创建一个图片走廊)
2012/08/24 Javascript
createTextRange()的使用示例含文本框选中部分文字内容
2014/02/24 Javascript
javascript判断chrome浏览器的方法
2014/03/26 Javascript
JavaScript函数定义的常见注意事项小结
2014/09/16 Javascript
谷歌浏览器调试JavaScript小技巧
2014/12/29 Javascript
nodejs通过phantomjs实现下载网页
2015/05/04 NodeJs
运用jQuery写的验证表单(实例讲解)
2017/07/06 jQuery
ajax+node+request爬取网络图片的实例(宅男福利)
2017/08/28 Javascript
jQuery Dom元素操作技巧
2018/02/04 jQuery
Vue 重置组件到初始状态的方法示例
2018/10/10 Javascript
python代码实现ID3决策树算法
2017/12/20 Python
用Pycharm实现鼠标滚轮控制字体大小的方法
2019/01/15 Python
在Python文件中指定Python解释器的方法
2019/02/18 Python
pandas DataFrame行或列的删除方法的实现示例
2019/08/02 Python
详解mac python+selenium+Chrome 简单案例
2019/11/08 Python
解决django框架model中外键不落实到数据库问题
2020/05/20 Python
python模拟点击在ios中实现的实例讲解
2020/11/26 Python
CSS3的Border-radius轻松制作圆角
2012/12/24 HTML / CSS
CSS3中background-clip和background-origin的区别示例介绍
2014/03/10 HTML / CSS
德国圣伯纳德草药屋:Kräuterhaus Sanct Bernhard(有中文站)
2018/08/05 全球购物
慕尼黑山地运动、户外服装和体育用品专家:Sporthaus Schuster
2019/08/27 全球购物
Tahari ASL官方网站:高级设计师女装
2021/03/15 全球购物
电子商务专员岗位职责
2013/12/11 职场文书
房地产公司见习自我鉴定
2014/04/28 职场文书
质量承诺书格式
2014/05/20 职场文书
党委班子剖析材料
2014/08/21 职场文书
小学运动会报道稿
2014/10/04 职场文书
劳动保障个人工作总结
2015/03/04 职场文书
爸爸的三轮车观后感
2015/06/16 职场文书
详解使用 CSS prefers-* 规范提升网站的可访问性与健壮性
2021/05/25 HTML / CSS