百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

响应式布如何用JS判断iPhone、iPad或PC(电脑)?

xsobi 2024-12-03 04:54 1 浏览

我们web前端人员常常接到轮播广告的项目,并且还要采用响应式,轮播广告上有两个特效:1.鼠标经过图片变亮,2.点击图会切换成文字描述的层且覆盖图片。正常情况下在pc端是没问题,但是移到移动端情况就有变了,如pad上面就会需要点击两下才能切换,为了解决这种问题,我们采用“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。代码如下:

  1. function is_iPad(){

  2. var ua = navigator.userAgent.toLowerCase();

  3. if(ua.match(/iPad/i)=="ipad") {

  4. return true;

  5. } else {

  6. return false;

  7. }

  8. }

拿 我碰到的那个问题实践下,原生代码是这样的:

  1. $(function(){

  2. $(".wangge").hover(function(){

  3. $(this).fadeOut()

  4. },function(){

  5. $(this).fadeIn();

  6. });

  7. })

我现在需要在PC端执行这段代码,在IPAD上不执行,于是我进行一下处理:

  1. $(function(){

  2. var ua = navigator.userAgent.toLowerCase();

  3. $(".wangge").hover(function(){

  4. if(ua.match(/iPad/i)=="ipad") {

  5. } else {

  6. $(this).fadeOut();

  7. }

  8. },function(){

  9. if(ua.match(/iPad/i)=="ipad") {

  10. } else {

  11. $(this).fadeIn();

  12. }

  13. });

  14. })

我们发现在ipad的时候是空值,其实您也可以写上return:false,我这里没写是因为会影响其他部分的JS代码效果。

这里可以多补充下,如果在PHP代码里,我们可以这样来:

  1. $is_iPad = (bool) strpos($_SERVER['HTTP_USER_AGENT'],'iPad');

或者

  1. <?php

  2. $agent = strtolower($_SERVER['HTTP_USER_AGENT']);

  3. $is_pc = (strpos($agent, 'windows nt')) ? true : false;

  4. $is_iphone = (strpos($agent, 'iphone')) ? true : false;

  5. $is_ipad = (strpos($agent, 'ipad')) ? true : false;

  6. if($is_pc){

  7. echo "PC机";

  8. }

  9. if($is_iphone){

  10. echo "iPhone";

  11. }

  12. if($is_ipad){

  13. echo "iPad";

  14. }

  15. ?>

同样我们也可以用Java代码来弄,如下:

  1. RewriteCond %{HTTP_USER_AGENT} ^.*iPad.*$

  2. RewriteRule ^(.*)$ http://ipad.fairyfish.net [R=301]

如果是 iPad 浏览器,跳转到 iPad 页面。

最后总结:

上面的方法,在做响应式布局的项目中常常遇到,希望它能帮助到您。

切图网(qietu.com)是一家专门从事web前端开发的公司,专注we前端开发,关注用户体验,欢迎订阅微信公众号:qietuwang

相关推荐

一文揭秘领域驱动设计(DDD):领域和子域

★★★建议星标我们★★★2020年Java原创面试题库连载中...

DDD领域驱动设计最全详解(图文全面总结)

DDD领域驱动设计是现在非常火热的设计架构,而且大厂面试也经常考察,下面我就全面来详解DDD领域驱动设计@mikechen本篇已收于mikechen原创超30万字《...

领域驱动设计(Domain-Driven Design)的关键概念

领域驱动设计(Domain-DrivenDesign,DDD)是一种软件开发方法,旨在通过深刻理解业务领域来构建复杂的系统。在DDD中,开发者与领域专家密切合作,共同定义业务逻辑,并通过模型表达领...

终于有人把安卓程序员必学知识点全整理出来了,有如醍醐灌顶

阅读前请点击右上角“关注”,每天免费获取Android知识解析及面试解答。Android架构解析,只做职场干货,完全免费分享!Java相关无论什么级别的Android从业者,Java作为Android...

[Android开发]使用观察者的正确姿势

前言首先先问一个问题,你在做Android开发的时候有没有被传值整的蒙圈?例如Fragment之间的传值,Activity之间的传值(ActivityForResult比较常用),Fragment与A...

大厂永恒敲门砖——Android 系统启动流程详解

...

Android音频开发:如何采集一帧音频

AndroidSDK提供了两套音频采集的API,分别是:MediaRecorder和AudioRecord,前者是一个更加上层一点的API,它可以直接把手机麦克风录入的音频数据进行编码压缩(如...

安卓手机怎么录屏?这三种方法你还不会用么?

手机录屏指的是使用手机的录屏功能,将屏幕上的内容进行录制,保存为视频文件,以供后续观看或分享。使用手机录屏功能,可以方便地将手机屏幕上的任何内容进行录制,无论是游戏操作、软件教程、视频播放等,只需要点...

网易视频云技术分享:Android 消息机制学习

Android消息机制大家都不陌生,想必大家也都看过Handler、Looper的源码(看过可以直接看末尾重点,一款监控APP卡顿情况的控件),下面,网易视频云技术专家就整合一下这方面的资料,加深对这...

2021年四大流行Android手机自动化测试工具,全在这里了

Android自动化测试的工具非常多,但是目前主流使用的就那几个,我会详细说明他们各自的情况,你可以根据自己的需要决定使用哪款工具。...

好程序员Android培训 122天炼成技术达人稳赚高薪

好程序员从课程研发到开班至今,历经一年的时间,专注Android和iOS开发高端人才培养,目前已经毕业的三期学员,从平均薪资的11000到三期的16000,薪资记录在行业内遥遥领先。面对如此“诱人”的...

娃哈哈基课堂第3课。安卓手机的盲人模式深度讲解

上一节课我们说了苹果手机的盲人模式如何设置?今天我们通过长文的方式来讲解安卓手机的盲人设置是如何设置的,所有的安卓手机盲人模式都是通用的,但是有一些手机因为优化系统的问题无法通用,或者有些手机直接把安...

android培训学习的大纲 android软件开发培训

第一阶段android基础:1.基础javaJava概述,进制,数据类型,常量变量,运算符,表达式关系运算符,逻辑运算符,if语句,switch语句while循环,do...while循环,for循环...

Android Jetpack从入门到精通(深度好文,值得收藏)

阅读前请点击右上角“关注”,每天免费获取Android知识解析及面试解答。Android架构解析,只做职场干货,完全免费分享!前言即学即用AndroidJetpack系列Blog的目的是通过学习An...

小技巧:安卓苹果都有!这份玩机的教程,我愿称为最强

从提起适老化这个概念到现在,能真正感受到的,可能只是App上的一个按钮。...