今天在做一个轮播广告的项目,轮播广告上有两个特效:第一就是鼠标经过图片变亮,再就是点击图会切换成文字描述的层且覆盖图片。通常这样的效果在PC端没什么问题的,但是到iPad上面就会需要点击两下才能切换,所以我想了想,有没有办法让ipad上只执行点击的JS代码,而不执行滑动的代码,于是就想到了“用js判断终端设备”来解决这个问题,下面就分享下方法:
iPad 使用的是 Safarimobile浏览器,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。代码如下:
拿 我碰到的那个问题实践下,原生代码是这样的:
我现在需要在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');
或者
同样我们也可以用java代码来弄,如下:
RewriteCond %{HTTP_USER_AGENT} ^.*iPad.*$
RewriteRule ^(.*)$ http://ipad.fAIryfish.net [R=301]
如果是 iPad 浏览器,跳转到 iPad 页面。
总结:
上面提到的这个问题,在做响应式布局的时候经常会遇到,如果掌握了它,相信在以后的类似项目中会运用的游刃有余了。好啦,就说这么多吧,如果您有问题,都可以给我在线留言,我都会第一时间给您回复。






网友评论文明上网理性发言已有0人参与
发表评论: