A. PHP判断是手机端还是PC端 PHP判断是否是微信浏览器
用php是可以判断抄,用js插件也是可以判断的,建议你安装一个modernizr.js插件 ,用法网上自己搜。其中一个用法就是区分pc和手机的,思想就是如果是pc 端 在<html>元素中有一个no-tuch 类。如果是手机端在html元素中会有一个touch类。这样你在前端控制css样式或是不同的js效果都非常方便。也非常容易开发出自适应页面。
B. 如何识别浏览器是微信,并弹出图片提示
1、如何识别浏览器是微信:
W3C标准要求浏览器具有navigator这个DOM对象,此对象使用userAgent属性来描述用户代理头,可以根据userAgent来对浏览器进行识别。
<html>
<body>
<scripttype="text/javascript">
document.write("<p>UserAgent:")
document.write(navigator.userAgent+"</p>")
</script>
</body>
</html>
上例将显示浏览器的用户代理头,如
Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12) AppleWebKit/602.1.50 (KHTML, like Gecko) Version/10.0 Safari/602.1.50
是来自Mac的Safari 10。
Mozilla/5.0 (iPhone; CPU iPhone OS 10_0_2 like Mac OS X) AppleWebKit/602.1.50 (KHTML, like Gecko) Mobile/14A456 MicroMessenger/6.3.27 NetType/WIFI Language/zh_CN
是来自iPhone的微信浏览器。
实际使用的时候,不需要关心userAgent的所有内容,只要抓住其关键字即可。从上面两个例子可以看出,Safari可取关键字“Safari”,微信可取关键字“MicroMessenger”。
2、如何弹出图片提示:
<html>
<body>
<!--
设计制作1.png作为微信浏览器进行浏览时弹出的提示图片,和此代码产生的html页面置于同目录
-->
<imgsrc="1.png"id="tips"style="display:none;"/>
<scripttype="text/javascript">
varua=navigator.userAgent;
if(ua.indexOf("MicroMessenger")>-1)
{//userAgent中检测到MicroMessenger关键字,是微信浏览器,弹出图片
document.getElementById("tips").style.display="block";
//下面这行代码用于没有做好提示图片时的替代
alert("这是微信浏览器");
}else
{//userAgent中没有检测到MicroMessenger关键字,不是微信浏览器
document.getElementById("tips").style.display="none";
}
</script>
</body>
</html>
C. 如何判断当前页面是否在微信浏览器中打开
方法一:使用JS判断。
function is_weixn(){
var ua = navigator.userAgent.toLowerCase();
if(ua.match(/MicroMessenger/i)=="micromessenger") {
return true;
} else {
return false;
}
}
方法二:使用PHP判断。
function is_weixin(){
if ( strpos($_SERVER['HTTP_USER_AGENT'], 'MicroMessenger') !== false ) { //strpos() 函数查找字符串在另回一字符串中第一次出现的位置。答
return true;
}
return false;
}
D. 如何判断当前页面是否在微信浏览器中打开
本文实例讲述了JS判断当前页面是否在微信浏览器打开的方法。分享给大家供大家参考,具体如下:
最近做很多HTML5的项目,很多页面会通过微信微博等SNS分享出去。在分享页面上提供公司APP的下载。但是在很多应用的浏览器中,点击下载链接无法下载应用。那么针对这些浏览器我们需要给用户提示从safari或者系统自带的浏览器打开分享页面。通过js就可以判断当前页面是在什么浏览器打开的。
以下是一段示例代码,注释中表明了通过JS如何判断是否在微信浏览器打开,是否在qq空间浏览器,是否在新浪微博打开。当然可以做得更完善一点,再加上判断是在移动设备打开还是在PC端浏览器打开的,更加细分一点,可以判断是在安卓系统的浏览器打开的还是IOS系统浏览器打开的。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
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浏览器,苹果浏览器,谷歌浏览器,火狐浏览器等。
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
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()
}
E. 如何判断微信内置浏览器,useragent
1、判断微信内置浏览器,首先需要获取微信内置浏览器的User Agent,经过在 iPhone 上微信的浏览器的检测,它的 User Agent 是:
Mozilla/5.0 (iPhone; CPU iPhone OS 6_1_3 like Mac OS X) AppleWebKit/536.26 (KHTML, like Gecko) Mobile/10B329 MicroMessenger/5.0.1
2、通过识别 MicroMessenger 这个关键字来确定是否微信内置的浏览器了。
3、具体方法:通过 JavaScript 判断
function is_weixin(){
var ua = navigator.userAgent.toLowerCase();
if(ua.match(/MicroMessenger/i)=="micromessenger") {
return true;
} else {
return false;
}
}
4、通过 PHP 判断
function is_weixin(){
if ( strpos($_SERVER['HTTP_USER_AGENT'], 'MicroMessenger') !== false ) {
return true;
}
return false;
}