使用JS判断设备终端是iPhone、iPad或者电脑(PC) - Web前端
作者:98wpeu发布时间:2026-05-10分类:网页前端技术浏览:55
今天在做一个轮播广告的项目,轮播广告上有两个特效:第一就是鼠标经过图片变亮,再就是点击图会切换成文字描述的层且覆盖图片。通常这样的效果在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 浏览器呢,关键是看它的 UserAgent 中是否有 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 页面。
总结:
上面提到的这个问题,在做响应式布局的时候经常会遇到,如果掌握了它,相信在以后的类似项目中会运用的游刃有余了。好啦,就说这么多吧,如果您有问题,都可以给我在线留言,我都会第一时间给您回复。
相关推荐
- jquery 学习之一 对象访问 - Web前端
- 基于jQuery的左右滚动实现代码 - Web前端
- 突发奇想的一个jquery插件 - Web前端
- jQuery 表单验证扩展(三) - Web前端
- JQuery学习笔记 nt-child的使用 - Web前端
- JQuery UI DatePicker中z-index默认为1的解决办法 - Web前端
- Jquery跨域获得Json时invalid label错误的解决办法 - Web前端
- jquery picswitch图片焦点图展示效果 - Web前端
- jQuery 表单验证扩展(三) - Web前端
- 使用jquery与图片美化checkbox和radio控件的代码(打包下载) - Web前端
- 网页前端技术排行
-
- 1【第六章】Foundation之按钮和下拉功能 - Web前端
- 2jQuery编写widget的一些技巧分享 - Web前端
- 3在Mac/PC上远程调试iPhone/iPad上的网页 - Web前端
- 4基于jquery的滚动条滚动固定div(附演示下载) - Web前端
- 5分析Iconfont-阿里巴巴矢量常用图标库 - Web前端
- 6jQuery实例教程:制作网页中可折叠的面板 - Web前端
- 7[Web前端]用javascript实现默认图片替代未显示的图片 - Web前端
- 8分享精心挑选的12款优秀jQuery Ajax分页插件和教程 - Web前端
- 9JS网页制作实例:标签云 - Web前端
- 最近发表
-
- WordPress随机显示特色图片插件:Random Post Thumbnails
- KeePass实现Chrome浏览器自动填充密码方法一
- LNMP一键包nginx 301强制跳转到https教程
- KeePass实现Chrome浏览器自动填充密码方法二
- #建站# 免费的VPS管理软件Xshell8/Xftp8中文版下载
- 使用Xshell 8连接VPS教程_电脑登录vps的方法
- WordPress评论界面添加烟花????效果
- 不同浏览器书签同步方案:坚果云+Floccus_详细使用教程
- iOS端KeePassXC客户端APP:Strongbox Password Safe
- 给WordPress评论中的Gravatar头像图片添加ALT属性


