CSS 自适应多屏大小的响应式设计布局 @media 

优点:无需 js检测、插件、手机主题等,对移动设备友好,能够适应各种窗口大小。

只需在CSS中添加@media screen属性,根据浏览器宽度判断并输出不同的长宽值。

 

@media 定义和使用

@media 可以针对不同的屏幕尺寸设置不同的样式,特别是如果你需要设置屏幕大小自适应的设计响应式的页面,@media 是非常有用的。

当你重置浏览器大小的过程中,页面也会根据浏览器的宽度和高度重新渲染页面。

浏览器支持,以下表格中的数字表示支持 @media 规则的第一个浏览器的版本号。

 

@media 常见写法

/* 文档宽度小于 300 像素则修改背景颜色(background-color) */
@media screen and (max-width: 300px) {
    body {
        background-color:lightblue;
    }
}

/*当屏幕尺寸小于600px时,应用下面的CSS样式 */
@media screen and (max-width: 600px) { 
  .class {
    background: #ccc;
  }
}

@media screen and (max-width: 600px) 是一种最常见的写法,后面跟上限定的屏幕尺寸

“max-width”是媒体特性中最常用的一个特性,其意思是指媒体类型小于或等于指定的宽度时,样式生效。

“min-width”与“max-width”相反,指的是媒体类型大于或等于指定宽度时,样式生效。

 

也可以针对不同的媒体使用不同 stylesheets css 文件

<link rel="stylesheet" media="mediatype and|not|only (media feature)" href="mystylesheet.css">

例如:在智能设备上,iPhone、iPad等,可以根据屏幕设备的尺寸来设置相应的样式(或者调用相应的样式文件)

同样的,对于屏幕设备同样可以使用“min/max”对应参数,如“min-device-width”或者“max-device-width”。

<link rel="stylesheet" media="screen and (max-device-width:480px)" href="iphone.css" />

上面的代码指的是“iphone.css”样式适用于最大设备宽度为480px,

比如说iPhone上的显示,这里的“max-device-width”所指的是设备的实际分辨率,也就是指可视面积分辨率。

 

@media 媒体类型

描述
all 用于所有设备(PC、iPad、iPhone、Xbox、电视、打印机
aural 已废弃。用于语音和声音合成器
braille 已废弃。 应用于盲文触摸式反馈设备
embossed 已废弃。 用于打印的盲人印刷设备
handheld 已废弃。 用于掌上设备或更小的装置,如PDA和小型电话
print 用于打印机和打印预览
projection 已废弃。 用于投影设备
screen 用于电脑屏幕,平板电脑,智能手机等。
speech 应用于屏幕阅读器等发声设备
tty 已废弃。 用于固定的字符网格,如电报、终端设备和对字符有限制的便携设备
tv 已废弃。 用于电视和网络电视

 

@media 媒体功能

描述
aspect-ratio 定义输出设备中的页面可见区域宽度与高度的比率
color 定义输出设备每一组彩色原件的个数。如果不是彩色设备,则值等于0
color-index 定义在输出设备的彩色查询表中的条目数。如果没有使用彩色查询表,则值等于0
device-aspect-ratio 定义输出设备的屏幕可见宽度与高度的比率。
device-height 定义输出设备的屏幕可见高度。
device-width 定义输出设备的屏幕可见宽度。
grid 用来查询输出设备是否使用栅格或点阵。
height 定义输出设备中的页面可见区域高度。
max-aspect-ratio 定义输出设备的屏幕可见宽度与高度的最大比率。
max-color 定义输出设备每一组彩色原件的最大个数。
max-color-index 定义在输出设备的彩色查询表中的最大条目数。
max-device-aspect-ratio 定义输出设备的屏幕可见宽度与高度的最大比率。
max-device-height 定义输出设备的屏幕可见的最大高度。
max-device-width 定义输出设备的屏幕最大可见宽度。
max-height 定义输出设备中的页面最大可见区域高度。
max-monochrome 定义在一个单色框架缓冲区中每像素包含的最大单色原件个数。
max-resolution 定义设备的最大分辨率。
max-width 定义输出设备中的页面最大可见区域宽度。
min-aspect-ratio 定义输出设备中的页面可见区域宽度与高度的最小比率。
min-color 定义输出设备每一组彩色原件的最小个数。
min-color-index 定义在输出设备的彩色查询表中的最小条目数。
min-device-aspect-ratio 定义输出设备的屏幕可见宽度与高度的最小比率。
min-device-width 定义输出设备的屏幕最小可见宽度。
min-device-height 定义输出设备的屏幕的最小可见高度。
min-height 定义输出设备中的页面最小可见区域高度。
min-monochrome 定义在一个单色框架缓冲区中每像素包含的最小单色原件个数
min-resolution 定义设备的最小分辨率。
min-width 定义输出设备中的页面最小可见区域宽度。
monochrome 定义在一个单色框架缓冲区中每像素包含的单色原件个数。如果不是单色设备,则值等于0
orientation 定义输出设备中的页面可见区域高度是否大于或等于宽度。
resolution 定义设备的分辨率。如:96dpi, 300dpi, 118dpcm
scan 定义电视类设备的扫描工序。
width 定义输出设备中的页面可见区域宽度。

 

@media 带 all 跟 only 的写法

only关键词

only用来指定某种特定的媒体类型,可以用来排除不支持媒体查询的浏览器。其实,only很多时候是用来对那些不支持Media Query但却支持Media Type的设备隐藏样式表的。其主要有:支持媒体特性的设备,正常调用样式,此时就当only不存在;表示不支持媒体特性但又支持媒体类型的设备,这样就会不读样式,因为其先会读取only而不是screen;另外不支持Media Queries的浏览器,不论是否支持only,样式都不会被采用。如

<linkrel="stylesheet" media="only screen and (max-device-width:240px)" href="android240.css" />

在Media Query中如果没有明确指定Media Type,那么其默认为all,如:

<linkrel="stylesheet" media="(min-width:701px) and (max-width:900px)" href="mediu.css" />

另外在样式中,还可以使用多条语句来将同一个样式应用于不同的媒体类型和媒体特性中,指定方式如下所示。

<linkrel="stylesheet" type="text/css" href="style.css" media="handheld and (max-width:480px), screen and (min-width:960px)" />

上面代码中style.css样式被用在宽度小于或等于480px的手持设备上,或者被用于屏幕宽度大于或等于960px的设备上。

 

一般all跟only都是对应在一起出现的

@media all and (min-width:xxx) and (max-width:1200px) {
/*这段查询的all是针对所有设备(有些设备不一定是屏幕,也许是打字机,盲人阅读器)*/
}
 
@media only screen and (min-width:960px) and (max-width:1200px) {
/*上面针对了所有设备,这段是只(only)针对彩色屏幕设备*/
}

 

not 关键词

使用关键词“not”是用来排除某种制定的媒体类型,也就是用来排除符合表达式的设备。换句话说,not关键词表示对后面的表达式执行取反操作,如:

@media not print and (max-width: 1200px){样式代码}

上面代码表示的是:样式代码将被使用在除打印设备和设备宽度小于1200px下所有设备中。

 

指定屏幕长宽比(device-aspect-ratio)

device-aspect-ratio可以用来适配特定屏幕长宽比的设备,这也是一个很有用的属性,比如,我们的页面想要对长宽比为4:3的普通屏幕定义一种样式,然后对于16:9和16:10的宽屏,定义另一种样式,比如自适应宽度和固定宽度: 

@media only screen and (device-aspect-ratio:4/3)

-webkit-min-device-pixel-ratio 的常见值对比,是设备上物理像素和设备独立像素,设备像素比率

设备 分辨率 设备像素比率
Android LDPI 320×240 0.75
Iphone 3 & Android MDPI 320×480 1
Android HDPI 480×800 1.5
Iphone 4 960×640 2.0

 

-webkit-min-device-pixel-ratio: 1.0

  • 所有非 Retina 的 Mac
  • 所有非 Retina 的 iOS 设备
  • Acer Iconia A500
  • Samsung Galaxy Tab 10.1
  • Samsung Galaxy S
  • 其他设备

-webkit-min-device-pixel-ratio为1.3

  • Google Nexus 7

-webkit-min-device-pixel-ratio为1.5

  • Google Nexus S
  • Samsung Galaxy S II
  • HTC Desire
  • HTC Desire HD
  • HTC Incredible S
  • HTC Velocity
  • HTC Sensation

-webkit-min-device-pixel-ratio为2.0

  • iPhone 4
  • iPhone 4S
  • iPhone 5
  • iPad (3rd generation)
  • iPad 4
  • 所有Retina displays 的MAC
  • Google Galaxy Nexus
  • Google Nexus 4
  • Google Nexus 10
  • Samsung Galaxy S III
  • Samsung Galaxy Note II
  • Sony Xperia S
  • HTC One X

-webkit-min-device-pixel-ratio: 3.0

  • HTC Butterfly
  • Sony Xperia S

 

总结

到目前为止,CSS3 Media Queries得到了众多浏览器支持,除了IE6-8浏览器不支持之外,在所有现代浏览器中都可以完美支持

还有一个与众不同的是,Media Queries在其他浏览器中不要像其他CSS3属性一样在不同的浏览器中添加前缀

 

 

参考推荐

PC端网页自适应手机屏幕大小

PC网站自动适配手机网页的方法技巧

WordPress 视频嵌入iframe自适应手机的初步解决方案

HTML CSS 字体大小 pt、px、em、rem 用法详解

BootStrap:一天完成把PC网站改为自适应

JS检测移动端自适应屏幕大小

mimvp-home  GitHub

22个最好的HTML/CSS定价表模板

26个jQuery使用技巧

Improve your jQuery – 25 excellent tips

jQuery 实现侧边浮动导航菜单效果

CSS+JS 悬浮固定菜单效果