最近做很多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()}
另一种方法:
用js来判断了,经过查找资料终于实现了效果,直接上代码
function is_weixn(){ var ua = navigator.useragent.tolowercase(); if(ua.match(/micromessenger/i)==micromessenger) { return true; } else { return false; } }
通过测试完全通过,无论是android 还是iphone,ipad 都可以,当然我们除了用js来判断之外,用其它语言来判断就更简单了,比如php
function is_weixin(){ if ( strpos($_server['http_user_agent'], 'micromessenger') !== false ) { return true; } return false; }
以上就是为大家分享了js判断当前页面用什么浏览器打开的方法,希望对大家的学习有所帮助。