IT兄弟连 HTML5教程 Media Queries的使用方法
在上例中,我们使用Media Queries模块来根据3种不同尺寸的窗口使用3种不同的样式。通过不同的媒体类型和条件定义样式表规则,媒体查询让CSS可以更精确地作用于不同的媒体类型和同一媒体的不同条件。媒体查询的大部分媒体特性都接受min和max用于表达“大于或等于”和“小与或等于”。例如,width会有min-width和max-width媒体查询可以被用在CSS中的@media和@import规则上,也可以被用在HTML和XML中。通过这个标签属性,我们可以很方便地在不同的设备下实现丰富的界面,特别是在移动设备上,媒体查询将会运用得更加广泛。媒体查询能够获取的值如下:
Ø 设备的宽和高(device-width,device-heigth),主要是显示屏幕或触觉设备。
Ø 渲染窗口的宽和高(width,heigth),主要是显示屏幕或触觉设备。
Ø 获取设备的手持方向,例如是横向还是竖向“orientation(portrait|lanscape)”,以及打印机设备等。
Ø 获取画面比例(aspect-ratio),包括点阵打印机等。
Ø 获取设备比例(device-aspect-ratio),包括点阵打印机等。
Ø 获取对象颜色或颜色列表(color,color-index),也包括显示屏幕。
Ø 获取设备的分辨率(resolution)。
1 语法结构及用法
媒体查询有两种使用方式:一种是在CSS样式中内嵌“@media”,在同一个CSS中通过不同窗口编写不同的样式去选择;另一种是使用外部样式表的引用,在@import和link中使用“@media”,根据不同的窗口大小选择对应的样式文件。这两种方式的使用方法是一样的。Media Queries的使用方法如下所示:
@media设备类型only (选取条件) not (选取条件) and (设备特性),设备二 { 样式代码 }
在CSS3的Media Queries模块中支持对外部样式表的引用,使用方法如下所示:
@import url(color.css) screen and (min-width: 1000px); /*使用@import导入CSS文件*/
或:
<link rel="stylesheet" type="text/css" media="only screen and (max-width: 480px),only screen and (max-device-width: 480px)" href="link.css" rel="external nofollow" /> /*使用link导入外部CSS文件*/
简写:
<link rel="stylesheet" type="text/css" media="screen and (max-width: 480px) href="link.css" />
上例中only可省略,限定于计算机显示器,第一个条件max-width是指渲染界面的最大宽度,第二个条件max-device-width是指设备最大宽度。在样式表中内嵌@media的代码示例如下所示:
@media (min-device-width:1024px) and (max-width:989px),screen and (max-device- width:480px),(max-device-width: 480px) and (orientation:landscape),(min-device- width:480px) and (max-device-width:1024px) and (orientation:portrait) { 样式代码 }
简写:
@media screen and (max-width:640px) { 样式代码 }
在上面的示例代码中,设置了计算机显示器分辨率(宽度)大于或等于1024px(并且最大可见宽度为989px);屏宽在480px及其以下手持设备;屏宽在480px及横向(即该尺寸平行于地面)放置的手持设备;屏宽大于或等于480px小于1024px及垂直放置设备的CSS样式。从上面的例子中可以看出,字符间以空格相连,选取条件包含在小括号内,样式代码为兼容设置的样式表,包含在中括号里面。only(限定某种设备,可省略)、and(逻辑与)、not(排除某种设备)为逻辑关键字,多种设备用逗号分隔,这一点继承了CSS的基本语法特性。
2 可用的设备类型
在上面的语法中,例如在CSS中嵌入“@media”的方式,开头必须书写“@media”,然后指定设备类型(上例使用screen代表计算机显示器)。CSS中定义了10种设备类型,可以指定的值与该值所代表的设备类型如表3-1所示。
表3-1 在Media Queries模块中可以指定的值与该值所代表的设备类型

3 可用的设备特性参数
通过设备类型可以区分使用的设备,再通过设备特性参数来设置同一设备的不同型号。例如,通过设备类型指定计算机显示器,再通过设备特性参数指定使用多大屏幕的显示器。设备特性的书写方式与样式的书写方式很相似,分为两个部分,由冒号分隔,冒号前书写设备的某种特性,冒号后书写该特性的具体值,例如“(min-width:320px)”。CSS中的设备特性共有13种,是一个类似于CSS属性的集合。但与CSS属性不同的是,大部分设备特性的指定接受min/max的前缀用来表示大于等于或小于等于的逻辑,以此避免使用“<”和“>”等字符。对于这13种设备特性参数的说明如表3-2所示。
表3-2 13种设备特性的说明



可以使用and关键字来指定当某种设备类型的某种特性的值满足某个条件时所使用的样式。例如以下语句指定了当设备窗口宽度小于640px时所使用的样式:
@media screen and (max-width: 640px) { 样式代码 }
可以使用多条语句来将同一个样式应用于不同的设备类型和设备特性中,指定方式类似如下所示:
@media handheld and (min-width:360px),screen and (max-width: 480px) { 样式代码 }
可以在表达式中加上not或only关键字。not关键字表示对后面的表达式执行取反操作,书写方法类似如下所示:
/* 样式代码将被用在除便携设备之外的其他设备或非彩色便携设备中 */
@media not handheld and (color) { 样式代码 }
/* 样式代码将被用在非彩色设备中 */
@media all and (not color) { 样式代码 }
使用only关键字的作用是让那些不支持Media Queries但是能够读取Media Type的设备的浏览器将表达式的样式隐藏起来。例如:
@media only screen and (color) { 样式代码 }
上面的语句对于支持Media Queries的设备来说,将能够正确应用样式,就像only不存在一样。对于不支持Media Queries但能够读取Media Type的设备(例如IE 8只支持“@media screen”)来说,由于先读到的是only而不是screen,将忽略这个样式。对于不支持Media Queries的浏览器(例如IE 8之前的浏览器)来说,无论是否有only,都将忽略这个样式。
IT兄弟连 HTML5教程 Media Queries的使用方法的更多相关文章
- IT兄弟连 HTML5教程 响应式布局实例
在学习Media Queries模块前,先通过一个响应式布局实例来了解一下响应式布局和Media Queries模块的简单应用.在本例中,使用HTML5的结构元素定义了5个盒子.当浏览器窗口尺寸不同时 ...
- IT兄弟连 HTML5教程 多媒体应用 小结及习题
小结 在互联网上,图像和链接则是通过URL唯一确定信息资源的位置.URL分为绝对URL和相对URL.通过使用<img />标记在浏览器中显示一张图像.超文本具有的链接能力,可层层链接相关文 ...
- IT兄弟连 HTML5教程 CSS3揭秘 小结及习题
小结 CSS3对于开发者来说,给web应用带来了更多的可能性,极大提高了开发效率.CSS3在选择器上的支持可谓是丰富多彩,使得我们能够灵活的控制样式,而不必为元素进行规范化的命名.CSS3支持的动画类 ...
- IT兄弟连 HTML5教程 HTML文档头部元素head
HTML头部标记是<head>,主要包括页面的一些基本描述语句,以及CSS和JavaScript,一般都可以定义在头部元素中.它用于包含当前文档的有关信息,例如网页标题和关键字等.通常位于 ...
- IT兄弟连 HTML5教程 HTML5表单 小结及习题
小结 HTML表单提交的方法有get方法和post方法,get方法的作用是从指定的资源请求数据,post方法的作用是向指定的资源提交要被处理的数据.HTML表单一直都是Web的核心技术之一,有了它我们 ...
- IT兄弟连 HTML5教程 HTML5表单 H5表单提交综合实例
这里我们创建一个填写个人基本信息的表单,使用了表单元素有<input>输入框.<datalist>选项列表.<textarea>文本框,通用的表单输入类型有text ...
- IT兄弟连 HTML5教程 HTML5表单 新增的表单属性1
HTML5 Input表单为<form>和<input>标签添加了几个新属性,属性如表1. 1 autocomplete属性 autocomplete属性规定form或inp ...
- IT兄弟连 HTML5教程 HTML5表单 多样的输入类型2
4 range range类型用于包含一定范围内数字值的输入域,跟number一样,我们还可以对数值设置限定,range类型显示为滑动条用法如下: 上述代码使用了range类型输入框,为该类型设置了 ...
- IT兄弟连 HTML5教程 HTML5表单 多样的输入类型1
HTML5拥有多个新的表单输入类型,这些新特性提供了更好的输入控制和验证.并不是所有的主浏览器都支持新的input类型,不过我们可以在所有的主浏览器中使用它们,即使不被支持,仍然可以显示为常规的文本域 ...
随机推荐
- Leetcode_01【两数之和】
文章目录: 题目 脚本一及注释 脚本逻辑 脚本二及注释 脚本逻辑 题目: 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. ...
- 复习sed实例操作
第6周复习课(5月2日) 课程内容: 复习 扩展1.打印某行到某行之间的内容http://ask.apelearn.com/question/5592.sed转换大小写 http://ask.apel ...
- 小白的springboot之路(七)、事务支持
0-前言 事务管理对于企业级应用来说必不可少,用来确保数据的完整性和一致性: 1-开启事务 spring boot支持编程式事务和声明式事务,用声明式事务即可: spring boot开启事务非常简单 ...
- Flask容器化部署原理与实现
本文将介绍Flask的部署方案:Flask + Nginx + uWSGI,并使用docker进行容器化部署,部署的实例来源 Flask开发初探,操作系统为ubuntu. Flask系列文章: Fla ...
- Spring Boot2 系列教程(三十)Spring Boot 整合 Ehcache
用惯了 Redis ,很多人已经忘记了还有另一个缓存方案 Ehcache ,是的,在 Redis 一统江湖的时代,Ehcache 渐渐有点没落了,不过,我们还是有必要了解下 Ehcache ,在有的场 ...
- SpringBoot 发送邮件功能实现
背景 有个小伙伴问我你以前发邮件功能怎么弄的.然后我就给他找了个demo,正好在此也写一下,分享给大家. 理清痛点 发送邮件,大家可以想一下,坑的地方在哪? 我觉得是三个吧. 第一:邮件白名单问题. ...
- Python开发GUI工具介绍,实战:将图片转化为素描画!
欢迎添加华为云小助手微信(微信号:HWCloud002 或 HWCloud003),输入关键字"加群",加入华为云线上技术讨论群:输入关键字"最新活动",获取华 ...
- 【nodejs原理&源码赏析(6)】深度剖析cluster模块源码与node.js多进程(下)
[摘要] cluster模块详解 示例代码托管在:http://www.github.com/dashnowords/blogs 阅读本章需要先阅读本系列前两章内容预热一下. 一. 引言 前两篇博文中 ...
- Internet History,Technology,and Security - Dawn of Electronic Computing(Week 1)
一 War Time Computing and Communication 讲到电子计算机,你不得不提起第二次世界大战,虽说二战是人类历史上史无前例的大灾难,不过从某种程度来说,它确实促进了社会的发 ...
- iOS 玩转推送通知
转自:http://www.cocoachina.com/ios/20160316/15665.html 前言 推送通知,想必大家都很熟悉,关于原理之类的,这里就不过多阐述.在这里我们主要介绍下iOS ...