原文链接:Introduction to CSS3 Media Queries

原文日期: 2014年2月21日

翻译日期: 2014年2月26日

翻译人员: 铁锚

简介

随着移动设备的日益普及,web开发人员需要确保他们的网站在不同的设备上都能良好展现。在显示时的一个重要手段就是为不同的设备应用不同的CSS规则。为此CSS3媒体查询(media queries)允许您根据不同的媒体类型及其功能应用不同的CSS规则。本文探讨CSS3媒体查询是什么以及如何在您的web页面中使用它们。

CSS3 Media Queries概述

要了解CSS3媒体查询,让我们假设您希望创建一个web页面,可以由台式电脑以及移动设备访问。PC机访问您的web页面时将使用一个功能丰富,分辨率和颜色都得到良好支持的屏幕设备。在这样的设备上你可以很容易地显示三列布局,中间列用来显示web页面的核心内容,剩下的两列则可以显示一些辅助内容或广告。如果同样的web页面由智能手机访问,你不能使用这样的布局,因为屏幕的宽度和高度是有限的。在这种情况下,您可能只想显示由核心内容组成的一列。除了布局以外还可以调整字体大小和颜色等其他方面。这需要根据不同的请求设备运用不同的CSS规则。这就是CSS3媒体查询的用武之地。使用CSS3媒体查询您可以指定媒体类型和功能的列表,如果请求设备符合指定的标准CSS规则,则将接下来的规则应用于web页面并显示给用户。不仅仅是CSS规则,你也可以根据请求设备切换整个样式表。

下面的图片显示了同样的web页面在桌面电脑和iPhone(实际上是通过Safari桌面浏览器模拟)上如何显示。

图1 网页在PC端与iPhone上的对比

这两种界面都包含同样的 <div> 元素。第一个是桌面显示效果,而第二个是移动版本效果。这种变化是通过CSS3媒体查询实现的。

媒体查询(media query)可以使用媒体类型和媒体特性。媒体类型表明目标设备类型。媒体类型包括:

  • all (所有设备类型)
  • screen (电脑屏幕)
  • handheld (手持设备)
  • tv (电视类型设备)

媒体特性包括一些参数:

  • 浏览器窗口的最大,最小尺寸(width and height)
  • 屏幕的宽高(width and height)
  • 屏幕方向(landscape or portrait)

现在你对媒体查询有了一些基本的了解,让我们继续学习如何编写媒体查询。

编写 Media Queries

正如前面所提到的,我们可以通过两种方式来使用CSS查询。第一种是将编写的媒体查询置于 <link> 标签中,当媒体查询表达式计算为true时,会加载指定的样式表,或者可以将编写的媒体查询放置在样式表文件内,当媒体查询表达式计算为true时就会应用相应的CSS规则。

让我们先看看如何编写媒体查询放置在一个样式表文件中。这种技术需要使用 @media CSS规则。要了解 @media 的使用,请创建一个新的HTML页面并添加以下标记:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <title></title>
    <link href="StyleSheet1.css" rel="stylesheet" />
</head>
<body>
    <div class="mycontent">
        Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World!
        Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World!
        Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World!
        Hello World! Hello World! Hello World! Hello World! Hello World! Hello World! Hello World!
    </div>
</body>
</html>

上面的页面包含一个<div>元素,并附有mycontent
CSS类。<div>包含了一些测试内容。 mycontent CSS类定义在 StyleSheet1.css中。因此,创建一个新的样式表并命名为StyleSheet1.css。然后添加CSS样式规则:

@media (min-width: 1000px) {
  .mycontent
  {
    width:500px;
    background-color:#ffd800;
    color:#ff0000;
    border:2px solid red;
    padding:5px;
  }
}

@media (max-width: 600px) {
  .mycontent {
    width:200px;
    background-color:#00ff90;
    color:navy;
    border:2px solid darkblue;
    padding:2px;
  }
}

上面的CSS定义了两个媒体查询。第一个媒体查询检查是否min-width属性至少600像素。min-width属性指明设备上可见区域的最低要求。在上面的例子中,如果这最低可见面积大于1000 px,则指定的 mycontent CSS类规则将应用于<div>元素。第二个媒体查询使用
max-width 属性。最大宽度属性表明,如果查看面积小于600 px,将应用接下来的CSS规则。

在台式电脑上测试上面的媒体查询,在浏览器(例如Chrome)中打开web页面,将浏览器窗口最大化,以便查看面积大于1000 px。下图显示了在这种条件下web页面的样子:

图2 宽度大于1000 px

现在,改变浏览器窗口的大小直到小于600 px,则显示内容应该改变为下面的样子:

图 3 宽度小于 600 px

当然,目前我们还没有考虑查看区域在600px - 1000px之间的情况,但是你可以轻易地为这些情况下提供一个默认mycontent类。

在上面的媒体查询中,没有显式地为 "all" 指定媒体类型。

当然你也可以使用媒体类型来实现等价的效果:

@media screen and (min-width: 1000px) {
  .mycontent
  {
    width:500px;
    background-color:#ffd800;
    color:#ff0000;
    border:2px solid red;
    padding:5px;
  }
}

@media screen and (max-width: 600px) {
  .mycontent {
    width:200px;
    background-color:#00ff90;
    color:navy;
    border:2px solid darkblue;
    padding:2px;
  }
}

可以看到,上面的查询使用了媒体类型
screen 以及 媒体特性min-width和max-width.

您还可以在媒体查询中指定多个条件。例如,您可以编写以下媒体查询来兼容查看区域 在600 px - 1000 px之间的情况。

@media (min-width: 600px) and (max-width:1000px) {
  .mycontent {
    width:350px;
    background-color:#ff00dc;
    color:navy;
    border:2px solid #4800ff;
    padding:2px;
  }
}

可以看到上面的媒体查询组合了 min-width和max-width参数。如果你调整浏览器窗口,当查看区域处于上述范围时你会看到显示效果如下:

图 4 宽度在 600 px - 1000px之间

在上面的例子中使用了可见区域的宽度。如果你想使用屏幕的尺寸来检查,你可以使用max-device-width 和 max-device-height参数。要了解更多媒体查询细节, 请点击这里

使用媒体查询切换样式表

在前面的例子中,你使用单个样式表来管理不同媒体查询。有时你可能需要对不同的媒体特性使用完全不同的样式表。例如,您可能有一个用于大屏幕尺寸的样式表。其中是针对台式电脑的 字体、字体大小、颜色和整体布局样式。另一方面你可能对移动设备上的web页面定义了完全不同的外观和感觉,如字体、字体大小和布局元素。在这种情况下将各自的风格放在不同的样式表文件中更整洁也更容易维护。

要让浏览器应用哪个样式表,您需要指定一个媒体查询到web页面的<link>元素中。考虑使用以下标记:

<link href="StyleSheet2.css" rel="stylesheet" media="screen and (min-width: 1000px)" />
<link href="StyleSheet3.css" rel="stylesheet" media="screen and (max-width: 600px)" />

上面的标记告诉浏览器,如果媒体查询中指定的媒体属性计算为true则使用StyleSheet2.css。在这种情况下,媒体查询检查请求设备可视面积是否大于1000 px。第二行的标记指定如果可视面积小于600 px,则应用StyleSheet3.css。

从上面的例子可以看到,媒体查询中提到的媒体属性与你早些时候使用的 @media是相同的。 要测试媒体属性,将mycontent CSS类的两个版本放置在两个样式表中(StyleSheet2.css和StyleSheet3.css),然后在主网页添加上面的标记。如果您在浏览器中打开web页面,你应该得到与之前判断浏览器尺寸时相同的结果。

总结

CSS3媒体查询允许您基于媒体类型(media type)和媒体特性(media features)应用CSS规则。这使得根据请求设备应用不同的CSS规则变得容易。诸如设备尺寸,可视区域和屏幕方向等媒体特性,可以使用媒体查询进行测试。总的来说,媒体查询是一个受欢迎的CSS新功能,为移动设备开发网站的web开发人员将会发现这个功能特别有吸引力。

相关阅读

Using CSS3 to Jazz up your Web Forms

Creating a Complete Web Page With HTML5

CSS3 Media Queries 简介的更多相关文章

  1. 移动终端学习1:css3 Media Queries简介

    移动终端学习之1:css3 Media Queries简介 1.简介 这篇文章写的不错,我就不重复了,来个链接:http://www.w3cplus.com/content/css3-media-qu ...

  2. 移动终端学习一:css3 Media Queries简介

    移动终端学习之一 css3 Media Queries简介 1.简介 别人写过的我就不重复了,来个链接:http://www.w3cplus.com/content/css3-media-querie ...

  3. CSS3 Media Queries 实现响应式设计

    在 CSS2 中,你可以为不同的媒介设备(如屏幕.打印机)指定专用的样式表,而现在借助 CSS3 的 Media Queries 特性,可以更为有效的实现这个功能.你可以为媒介类型添加某些条件,检测设 ...

  4. 【CSS3 入门教程系列】CSS3 Media Queries 实现响应式设计

    在 CSS2 中,你可以为不同的媒介设备(如屏幕.打印机)指定专用的样式表,而现在借助 CSS3 的 Media Queries 特性,可以更为有效的实现这个功能.你可以为媒介类型添加某些条件,检测设 ...

  5. CSS3 Media Queries 片段

    CSS3 Media Queries片段 在这里主要分成三类:移动端.PC端以及一些常见的响应式框架的Media Queries片段. 移动端Media Queries片段 iPhone5 @medi ...

  6. HTML5实践 -- 使用CSS3 Media Queries实现响应式设计

    CSS3 Media用法介绍:http://www.w3cplus.com/content/css3-media-queries 转载请注明原创地址:http://www.cnblogs.com/so ...

  7. CSS3 Media Queries模板

    使用max-width @media screen and (max-width: 600px) { //你的样式放在这里.... } 使用min-width @media screen and (m ...

  8. CSS3 Media Queries在iPhone4和iPad上的运用

    CSS3 Media Queries的介绍在W3CPlus上的介绍已有好几篇文章了,但自己碰到的问题与解决的文章还是相对的较少.前几天在<修复iPhone上submit按钮bug>上介绍了 ...

  9. Css3 Media Queries移动页面的样式和图片的适配问题(转)

    CSS3 Media Queries 摘自:http://www.w3cplus.com/content/css3-media-queries Media Queries直译过来就是“媒体查询”,在我 ...

随机推荐

  1. linux:CPU私有变量(per-CPU变量)

    一.简介2.6内核上一个新的特性就是per-CPU变量.顾名思义,就是每个处理器上有此变量的一个副本.per-CPU的最大优点就是,对它的访问几乎不需要锁,因为每个CPU都在自己的副本上工作.task ...

  2. Android 6.0出现的init: cannot execve(‘XXX’):Permission denied问题:禁止SELINUX的权限设置

    最近在开发MTK的相关项目,需要将一些可执行文件添加到init.rc文件里去,但是开机后发现,这个bin文件没有权限不能执行,于是我就在init.rc中对相应的bin文件增加了权限.后来发现,改了也没 ...

  3. python 3 黑色魔法元类初探

    最近读django源码,发现必须了解元类才能理解一些很神奇的行为. 发现元类实际上是控制class的创建过程.比如类B继承某个看似平淡无奇的类A之后,你在类B中定义的属性或方法可能会遭到彻底改变. 假 ...

  4. norflash启动和nandflash启动

    S3C2440的启动时读取的第一条指令是在0x00上,分为成nand flash和nor flash上启动. 1)nand flash:适合大容量数据存储,类似硬盘: 2)nor flash:适合小容 ...

  5. zk日常运维管理

    清理数据目录 dataDir目录指定了ZK的数据目录,用于存储ZK的快照文件(snapshot).另外,默认情况下,ZK的事务日志也会存储在这个目录中.在完成若干次事务日志之后(在ZK中,凡是对数据有 ...

  6. Dynamics CRM 非声明验证方式下连接组织服务的两种方式的性能测试

    今天看了勇哥的博文"http://luoyong0201.blog.163.com/blog/static/1129305201510153391392/",又认识到了一种新的连接 ...

  7. Android Paint类介绍以及浮雕和阴影效果的设置

    Paint类介绍 Paint即画笔,在绘制文本和图形用它来设置图形颜色, 样式等绘制信息. 1.图形绘制 setARGB(int a,int r,int g,int b); 设置绘制的颜色,a代表透明 ...

  8. J2EE进阶(十三)Spring MVC常用的那些注解

    Spring MVC常用的那些注解 前言 Spring从2.5版本开始在编程中引入注解,用户可以使用@RequestMapping, @RequestParam,@ModelAttribute等等这样 ...

  9. 01_MyBatis EHCache集成及所需jar包,ehcache.xml配置文件参数配置及mapper中的参数配置

     1 与mybatis集成时需要的jar ehcache-core-2.6.5.jar mybatis-ehcache-1.0.2.jar Mybatis.日志.EHCache所需要的jar包如下 ...

  10. 为你的MacOS App添加开机自启动(Swift)

    猴子原创,欢迎转载.转载请注明: 转载自Cocos2Der-CSDN,谢谢! 原文地址: http://blog.csdn.net/cocos2der/article/details/52104828 ...