今天在做一个轮播广告的项目,轮播广告上有两个特效:第一就是鼠标经过图片变亮,再就是点击图会切换成文字描述的层且覆盖图片。通常这样的效果在PC端没什么问题的,但是到IPAD上面就会需要点击两下才能切换,所以我想了想,有没有办法让ipad上只执行点击的JS代码,而不执行滑动的代码,于是就想到了“用JS判断终端设备”来解决这个问题,下面就分享下方法:
iPad 使用的是 Safari Mobile 浏览器,User Agent 是:
Mozilla/5.0 (iPad; U; CPU OS 3_2 like Mac OS X; en-us) AppleWebKit/531.21.10 (KHTML, like Gecko) Version/4.0.4 Mobile/7B334b Safari/531.21.10
如何判断是否是 iPad 浏览器呢,关键是看它的 User Agent 中是否有 iPad。代码如下:
function is_iPad(){
var ua = navigator.userAgent.toLowerCase();
if(ua.match(/iPad/i)=="ipad") {
return true;
} else {
return false;
}
}
拿 我碰到的那个问题实践下,原生代码是这样的:
$(function(){
$(".wangge").hover(function(){
$(this).fadeOut()
},function(){
$(this).fadeIn();
});
})
我现在需要在PC端执行这段代码,在IPAD上不执行,于是我进行一下处理:
$(function(){
var ua = navigator.userAgent.toLowerCase();
$(".wangge").hover(function(){
if(ua.match(/iPad/i)=="ipad") {
} else {
$(this).fadeOut();
}
},function(){
if(ua.match(/iPad/i)=="ipad") {
} else {
$(this).fadeIn();
}
});
})
我们发现在ipad的时候是空值,其实您也可以写上return:false,我这里没写是因为会影响其他部分的JS代码效果。
这里可以多补充下,如果在PHP代码里,我们可以这样来:
$is_iPad = (bool) strpos($_SERVER['HTTP_USER_AGENT'],'iPad');
或者
<?php
$agent = strtolower($_SERVER['HTTP_USER_AGENT']);
$is_pc = (strpos($agent, 'windows nt')) ? true : false;
$is_iphone = (strpos($agent, 'iphone')) ? true : false;
$is_ipad = (strpos($agent, 'ipad')) ? true : false;
if($is_pc){
echo "PC机";
}
if($is_iphone){
echo "iPhone";
}
if($is_ipad){
echo "iPad";
}
?>
同样我们也可以用Java代码来弄,如下:
RewriteCond %{HTTP_USER_AGENT} ^.*iPad.*$
RewriteRule ^(.*)$ http://ipad.fairyfish.net [R=301]
如果是 iPad 浏览器,跳转到 iPad 页面。
总结:
上面提到的这个问题,在做响应式布局的时候经常会遇到,如果掌握了它,相信在以后的类似项目中会运用的游刃有余了。好啦,就说这么多吧,如果您有问题,都可以给我在线留言,我都会第一时间给您回复。
网友评论文明上网理性发言已有0人参与
发表评论: