详解CSS3 Media Queries中媒体属性的使用


Posted in HTML / CSS onFebruary 29, 2016

媒体属性
大多数媒体属性带有“min-”和“max-”前缀,用于表达“小于等于”和“大于等于”。这避免了使用与HTML和XML冲突的“<”和“>”字符。如果你未向媒体属性指定一个值,并且该特性的实际值不为零,则该表达式被解析为真。

注意:如果浏览器运行的设备上没有该属性值,包含这个属性值的表达式一般返回假。例如,在语音合成器上查询屏幕长宽比总是返回假。
颜色(color)

值: <color>
媒体: visual
是否接受 min/max 前缀:是

指定输出设备每个像素单元的比特值。如果设备不支持输出颜色,则该值为0。

注意:如果每个颜色单元具有不同数量的比特值,则使用最小的。例如,如果显示器为蓝色和红色提供5比特,而为绿色提供6比特,则认为每个颜色单元有5比特。如果设备使用索引颜色,则使用颜色表中颜色单元的最小比特数。
示例

向所有能显示颜色的设备应用样式表:

CSS Code复制内容到剪贴板
  1. @media all and (color) { ... }  

向每个颜色单元至少有4个比特的设备应用样式表:

CSS Code复制内容到剪贴板
  1. @media all and (min-color: 4) { ... }  

颜色索引(color-index)

值:<integer>
媒体: visual
是否接受 min/max 前缀:是

指定了输出设备中颜色查询表中的条目数量。

示例

向所有使用索引颜色的设备应用样式表,你可以这么做:

CSS Code复制内容到剪贴板
  1. @media all and (color-index) { ... }  

向所有使用至少256个索引颜色的设备应用样式表:

CSS Code复制内容到剪贴板
  1. <link rel="stylesheet" media="all and (min-color-index: 256)" href="http://foo.bar.com/stylesheet.css" />  

宽高比(aspect-ratio)

值:<ratio>
媒体: visual, tactile
是否接受 min/max 前缀:是

描述了输出设备目标显示区域的宽高比。该值包含两个以“/”分隔的正整数。代表了水平像素数(第一个值)与垂直像素数(第二个值)的比例。

示例

下面为显示区域宽高至少为一比一的设备选择了一个特殊的样式表。

CSS Code复制内容到剪贴板
  1. @media screen and (min-aspect-ratio: 1/1) { ... }  

这指定了宽高比或者1:1或者更大。换句话说,可视区域或者是正方形或者是宽屏。

设备宽高比(device-aspect-ratio)

值:<ratio>
媒体:visual, tactile
是否接受 min/max 前缀:是

描述了输出设备的宽高比。该值包含两个以“/”分隔的正整数。代表了水平像素数(第一个值)与垂直像素数(第二个值)的比例。

示例

下面为宽屏设备选择了一个特殊的样式表。

CSS Code复制内容到剪贴板
  1. @media screen and (device-aspect-ratio: 16/9), screen and (device-aspect-ratio: 16/10) { ... }  

宽高比或者16:9或者16:10。

设备高度(device-height)

值:<length>
媒体:visual, tactile
是否接受 min/max 前缀:是

描述了输出设备的高度(整个屏幕或页的高度,而不是仅仅像文档窗口一样的渲染区域)。

示例

向显示在最大宽度800px的屏幕上的文档应用样式表,你可以这样做:

CSS Code复制内容到剪贴板
  1. <link rel="stylesheet" media="screen and (max-device-width: 799px)" />  

设备宽度(device-width)

值:<length>
媒体: visual, tactile
是否接受 min/max 前缀:是

描述了输出设备的宽度(整个屏幕或页的高度,而不是仅仅像文档窗口一样的渲染区域)。

网格(grid)

值:<integer>
媒体:all
是否接受 min/max 前缀: 否

判断输出设备是网格设备还是位图设备。如果设备是基于网格的(例如电传打字机终端或只能显示一种字形的电话),该值为1,否则为0。

示例

向一个15字符宽度或更窄的手持设备应用样式:

CSS Code复制内容到剪贴板
  1. @media handheld and (grid) and (max-width: 15em) { ... }  

注意:“em” 在网格设备中有不同的意义;一个“em”的实际宽度不得而知,假设1em相当于一个网格单元的宽高。
高度(height)

值:<length>
媒体:visual, tactile
是否接受 min/max 前缀:是

height 媒体属性描述了输出设备渲染区域(如可视区域的高度或打印机纸盒的高度)的高度。

注意:用户调整窗口大小后,火狐浏览器会根据使用了width和height属性的媒体查询来切换合适的样式表。
黑白(monochrome)

值:<integer>
媒体: visual
是否接受 min/max 前缀:是

指定了一个黑白(灰度)设备每个像素的比特数。如果不是黑白设备,值为0。

示例

向所有黑白设备应用样式表:

CSS Code复制内容到剪贴板
  1. @media all and (monochrome) { ... }  

向每个像素至少8比特的黑白设备应用样式表:

CSS Code复制内容到剪贴板
  1. @media all and (min-monochrome: 8) { ... }  

方向(orientation)

值:landscape | portrait
媒体:visual
是否接受 min/max 前缀:否

指定了设备处于横屏(宽度大于宽度)模式还是竖屏(高度大于宽度)模式。

示例

向竖屏设备应用样式表:

CSS Code复制内容到剪贴板
  1. @media all and (orientation: portrait) { ... }  

分辨率(resolution)

值: <resolution>
媒体: bitmap
是否接受 min/max 前缀:是

指定输出设备的分辨率(像素密度)。分辨率可以用每英寸(dpi)或每厘米(dpcm)的点数来表示。

示例

为每英寸至多300点的打印机应用样式:

CSS Code复制内容到剪贴板
  1. @media print and (min-resolution: 300dpi) { ... }  

替换老旧的 (min-device-pixel-ratio: 2) 语法:

CSS Code复制内容到剪贴板
  1. @media screen and (min-resolution: 2dppx) { ... }  

扫描(scan)

值: progressive | interlace
媒体:tv
是否接受 min/max 前缀:否

描述了电视输出设备的扫描过程。

示例

向以顺序方式扫描的电视机上应用样式表:

CSS Code复制内容到剪贴板
  1. @media tv and (scan: progressive) { ... }  

宽度(width)

值: <length>
媒体: visual, tactile
是否接受 min/max 前缀:是

width 媒体属性描述了输出设备渲染区域(如可视区域的宽度或打印机纸盒的宽度)的宽度。

注意:用户调整窗口大小后,火狐浏览器会根据使用了width和height属性的媒体查询来切换合适的样式表。
示例

如果你想向最小宽度20em的手持设备或屏幕应用样式表,你可以使用这样的查询:

CSS Code复制内容到剪贴板
  1. @media handheld and (min-width: 20em), screen and (min-width: 20em) { ... }  

这个媒体查询将向最小宽度8.5英寸的打印机应用样式表:

CSS Code复制内容到剪贴板
  1. <link rel="stylesheet" media="print and (min-width: 8.5in)"  
  2.     href="http://foo.com/mystyle.css" />  

这个查询适用于宽度在500px和800px之间的屏幕:

CSS Code复制内容到剪贴板
  1. @media screen and (min-width500px) and (max-width800px) { ... }  

实现响应式设计

这个例子可以调整你的浏览器窗口尺寸,我们来具体看一下:
Max Width
下面的样式会在可视区域的宽度小于 600px 的时候被应用。

CSS Code复制内容到剪贴板
  1. @media screen and (max-width600px) {   
  2.   .class {   
  3.     background#ccc;   
  4.   }   
  5. }  

如果你想链接到一个单独的样式表,把下面的代码放在<head>标签里。

CSS Code复制内容到剪贴板
  1. <link rel="stylesheet" media="screen and (max-width: 600px)" href="small.css" />  

Min Width
下面的样式会在可视区域的宽度大于 900px 的时候被应用。

CSS Code复制内容到剪贴板
  1. @media screen and (min-width900px) {   
  2.   .class {   
  3.     background#666;   
  4.   }   
  5. }  

Multiple Media Queries
你还可以使用过个匹配条件,下面的样式会在可视区域的宽度在 600px 和 900px 之间的时候被应用。

CSS Code复制内容到剪贴板
  1. @media screen and (min-width600px) and (max-width900px) {   
  2.   .class {   
  3.     background#333;   
  4.   }   
  5. }  

Device Width
下面的样式会在 max-device-width 是 480px 的设备上触发。(提示:max-device-width 是设备的实际分辨率,而 max-width 指的是可视区域分辨率。)

CSS Code复制内容到剪贴板
  1. @media screen and (max-device-width480px) {   
  2.   .class {   
  3.     background#000;   
  4.   }   
  5. }   

For iPhone 4
下面的样式是为 iPhone 4 专门写的 (作者: Thomas Maier)。

CSS Code复制内容到剪贴板
  1. <link rel="stylesheet" media="only screen and (-webkit-min-device-pixel-ratio: 2)" type="text/css" href="iphone4.css" />   

For iPad
你还可以使用 media query 在 iPad 上检测方向(portrait or landscapse) 

CSS Code复制内容到剪贴板

  1. <link rel="stylesheet" media="all and (orientation:portrait)" href="portrait.css">   
  2. <link rel="stylesheet" media="all and (orientation:landscape)" href="landscape.css">   
HTML / CSS 相关文章推荐
CSS3+DIV实现漂亮的动画彩色标签
Jun 16 HTML / CSS
CSS Grid布局教程之网格单元格布局
Dec 30 HTML / CSS
CSS3的column-fill属性对齐列内容高度的用法详解
Jul 01 HTML / CSS
利用CSS3实现文字折纸效果实例代码
Jul 10 HTML / CSS
详解CSS3新增的背景属性
Dec 25 HTML / CSS
Css3实现无缝滚动防抖
Sep 14 HTML / CSS
html5如何及时更新缓存文件(js、css或图片)
Jun 24 HTML / CSS
HTML5 LocalStorage 本地存储详细概括(多图)
Aug 18 HTML / CSS
CSS3实现三角形不断放大效果
Apr 13 HTML / CSS
HTML+css盒子模型案例(圆,半圆等)“border-radius” 简单易上手
May 10 HTML / CSS
CSS中float高度塌陷问题的四种解决方案
Apr 18 HTML / CSS
HTML静态页面获取url参数和UserAgent的实现
Aug 05 HTML / CSS
CSS3媒体查询Media Queries基础学习教程
Feb 29 #HTML / CSS
通过CSS3的object-fit来调整图片适配尺寸的技巧简介
Feb 27 #HTML / CSS
CSS3中currentColor关键字的妙用
Feb 27 #HTML / CSS
魔幻般冒泡背景的CSS3按钮动画
Feb 27 #HTML / CSS
CSS3 text-shadow实现文字阴影效果
Feb 24 #HTML / CSS
非常震撼的纯CSS3人物行走动画
Feb 24 #HTML / CSS
非常漂亮的CSS3百叶窗焦点图动画
Feb 24 #HTML / CSS
You might like
php的正则处理函数总结分析
2008/06/20 PHP
PHP中去掉字符串首尾空格的方法
2012/05/19 PHP
PHP中is_dir()函数使用指南
2015/05/08 PHP
PHP单链表的实现代码
2016/07/05 PHP
php5对象复制、clone、浅复制与深复制实例详解
2019/08/14 PHP
javascript 读取图片文件的大小
2009/06/25 Javascript
Js 代码中,ajax请求地址后加随机数防止浏览器缓存的原因
2013/05/07 Javascript
jquery 列表双向选择器之改进版
2013/08/09 Javascript
JavaScript实现图片DIV竖向滑动的方法
2015/04/25 Javascript
JavaScript学习笔记之数组求和方法
2016/03/23 Javascript
网页中JS函数自动执行常用三种方法
2016/03/30 Javascript
AngularJS基础 ng-mouseover 指令简单示例
2016/08/02 Javascript
正则表达式替换html元素属性的方法
2016/11/26 Javascript
Ext JS 实现建议词模糊动态搜索功能
2017/05/13 Javascript
基于Vue过渡状态实例讲解
2017/09/14 Javascript
详解node.js中的npm和webpack配置方法
2018/01/21 Javascript
BootStrap表单验证中的非Submit类型按钮点击时触发验证的坑
2019/09/05 Javascript
vue element ui validate 主动触发错误提示操作
2020/09/21 Javascript
解决vant中 tab栏遇到的坑 van-tabs
2020/11/04 Javascript
浅析Python中的序列化存储的方法
2015/04/28 Python
Python 点击指定位置验证码破解的实现代码
2019/09/11 Python
python openCV实现摄像头获取人脸图片
2020/08/20 Python
高街生活方式全球在线商店:AZBRO
2017/08/26 全球购物
Feelunique德国官方网站:欧洲最大的在线美容零售商
2019/07/20 全球购物
瑞典多品牌连锁店:Johnells
2021/01/13 全球购物
应用心理学个人的求职信
2013/12/08 职场文书
党的群众路线教育实践活动个人对照检查材料(校长)
2014/11/05 职场文书
先进党支部事迹材料
2014/12/24 职场文书
硕士学位论文评语
2014/12/31 职场文书
遗嘱继承权公证书
2015/01/26 职场文书
2015羊年春节慰问信
2015/02/14 职场文书
学习与创新自我评价
2015/03/09 职场文书
大学生暑假实习总结
2015/07/13 职场文书
教师节随笔
2015/08/15 职场文书
2016幼儿园教师年度考核评语
2015/12/01 职场文书
Python基础之元类详解
2021/04/29 Python