Detecting iPad / iPhone using media queries

2019-04-16 21:39发布

问题:

Am working on a project where I need to distinguish between the landscape and portrait modes of iPhone, iPad using media queries. Also, am using iPad 3, iPhone 4s. As simple and straightforward as this may sound, I am having the hardest time getting this to work. The closest I got to is this :-

@media (min-device-width: 768px)
and (max-device-width: 1024px)
and (orientation: portrait) {
/*iPad portrait*/
}

@media (min-device-width: 768px)
and (max-device-width: 1024px)
and (orientation: landscape) {
/*iPad landscape*/
}

@media (max-device-width: 480px)
and (orientation: portrait) {
/*iPhone portrait*/
}

@media (max-device-width: 480px)
and (orientation: landscape) {
/*iPhone landscape*/
}

But, this does not differentiate between the portrait / landscape modes of the iPhone. Any clues on what could be wrong ?

回答1:

Here is some sample code that demonstrates functioning queries on an iPhone. It is white in portrait, black in landscape. You can ignore the base64 part, that was just to supply an icon without needing an external file:

<!DOCTYPE html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="apple-mobile-web-app-status-bar-style" content="black" />
<link rel="apple-touch-icon" href=""/>
<meta name="viewport" content="initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
<title>Media</title>
<style>
html,body{width:100%;height:100%;margin:0;padding:0;}
@media screen and (max-device-width: 320px) and (orientation:portrait) {
    body { background-color:#FFF; }
}
@media screen and (max-device-width: 320px) and (orientation:landscape) {
    body { background-color:#000; }
}
</style>
</head>
<body onload="fullscreen()">
<span style="color:#000">Portrait</span><span style="color:#FFF">Landscape</span>
</body>
</html>


回答2:

I use the following media queries (defining splash images for web apps). It handles iPhone non-retina and iPhone 4/4s and both non-retina iPad and retina iPad (portrait and landscape). You can find this at https://github.com/gwilson/iOSWebAppTemplates

    <!-- iPhone standard resolution 320x460  (landscape not needed because all web apps start portrait on iPhone) -->
<link  rel="apple-touch-startup-image" href="splash-320x460.jpg" media="(device-width: 320px)" />
<!-- iPhone high resolution (retina) 640x920 pixels (landscape not needed because all web apps start portrait on iPhone) -->
<link rel="apple-touch-startup-image" href="splash-640x920.jpg" media="(device-width: 320px) and (-webkit-device-pixel-ratio: 2)" />
<!-- iPad Portrait 768x1004 -->
<link rel="apple-touch-startup-image" href="splash-768x1004.jpg" media="(device-width: 768px) and (orientation: portrait)" />
<!-- iPad Landscape 748x1024 (yes, a portrait image but with content rotated 90 degrees - allows 20px for status bar) -->
<link rel="apple-touch-startup-image" href="splash-748x1024.jpg" media="(device-width: 768px) and (orientation: landscape)" />
<!-- iPad retina Portrait 1536x2008 -->
<link rel="apple-touch-startup-image" href="splash-1536x2008.jpg" media="(device-width: 768px) and (orientation: portrait) and (-webkit-device-pixel-ratio: 2)" />
<!-- iPad retina Landscape 1496x2048 (yes, a portrait image but with content rotated 90 degrees - allows 40px for status bar) -->
<link rel="apple-touch-startup-image" href="splash-1496x2048.jpg" media="(device-width: 768px) and (orientation: landscape) and (-webkit-device-pixel-ratio: 2)" />


回答3:

<html>
<head>
<style type="text/css">

/* Mobile Layout: 480px and below. */
.gridContainer {
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    padding: 0;
    height: 300px;
    background: #ff0000;
}
#LayoutDiv1 {
    clear: both;
    float: left;
    margin-left: 0;
    width: 100%;
    display: block;
}

/* Tablet Layout: 481px to 768px. Inherits styles from: Mobile Layout. */
@media only screen and (min-width: 481px) {
.gridContainer {
    width: 80.675%;
    padding-left: 1.1625%;
    padding-right: 1.1625%;
    background: #00ff00;
    height: 200px;
}
#LayoutDiv1 {
    clear: both;
    float: left;
    margin-left: 0;
    width: 100%;
    display: block;
}
}

/* Desktop Layout: 769px to a max of 1232px.  Inherits styles from: Mobile Layout and Tablet Layout. */
@media only screen and (min-width: 769px) {
.gridContainer {
    width: 88.2%;
    max-width: 1232px;
    padding-left: 0.9%;
    padding-right: 0.9%;
    margin: auto;
    background: yellow;
    height: 100px;
}
#LayoutDiv1 {
    clear: both;
    float: left;
    margin-left: 0;
    width: 100%;
    display: block;
}
}
</style>
</head>

<body>
<div id="LayoutDiv1">
    <div class="gridContainer">Welcome to iPad</div>
</div>
</body>
</html>