媒体查询使用方法@media

Media Queries能在不一样的条件下使用不一样的样式,使页面在不一样在终端设备下达到不一样的渲染效果。前面简单的介绍了Media Queries如何引用到项目中,但Media Queries有其本身的使用规则。具体来讲,Media Queries的使用方法以下。css

@media 媒体类型and (媒体特性){你的样式}

注意:使用Media Queries必需要使用“@media”开头,而后指定媒体类型(也能够称为设备类型),随后是指定媒体特性(也能够称之为设备特性)。媒体特性的书写方式和样式的书写方式很是类似,主要分为两个部分,第一个部分指的是媒体特性,第二部分为媒体特性所指定的值,并且这两个部分之间使用冒号分隔。例如:android

(max-width: 480px)
从前面表中能够得知,主要有十种媒体类型和13种媒体特性,将其组合就相似于不一样的CSS集合。
但与CSS属性不一样的是,媒体特性是经过min/max来表示大于等于或小于作为逻辑判断,
而不是使用小于(<)和大于(>)这样的符号来判断。接下来一块儿来看看Media Queries在实际项目中经常使用的方式。

1. 最大宽度max-width浏览器

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

@media screen and (max-width:480px){
 .ads {
   display:none;
  }
}

上面表示的是:当屏幕小于或等于480px时,页面中的广告区块(.ads)都将被隐藏。iphone

2.最小宽度min-width

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

@media screen and (min-width:900px){
.wrapper{width: 980px;}
}

上面表示的是:当屏幕大于或等于900px时,容器“.wrapper”的宽度为980px。code

3.多个媒体特性使用

Media Queries能够使用关键词"and"将多个媒体特性结合在一块儿。也就是说,一个Media Query中能够包含0到多个表达式,表达式又能够包含0到多个关键字,以及一种媒体类型。ip

当屏幕在600px~900px之间时,body的背景色渲染为“#f5f5f5”,以下所示。io

@media screen and (min-width:600px) and (max-width:900px){
  body {background-color:#f5f5f5;}
}

4.设备屏幕的输出宽度Device Width

在智能设备上,例如iPhone、iPad等,还能够根据屏幕设备的尺寸来设置相应的样式(或者调用相应的样式文件)。一样的,对于屏幕设备一样可使用“min/max”对应参数,如“min-device-width”或者“max-device-width”。class

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

上面的代码指的是“iphone.css”样式适用于最大设备宽度为480px,好比说iPhone上的显示,这里的“max-device-width”所指的是设备的实际分辨率,也就是指可视面积分辨率。

5. not关键词

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

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

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

6.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的设备上。

到目前为止,CSS3 Media Queries获得了众多浏览器支持,除了IE6-8浏览器不支持以外,在全部现代浏览器中均可以完美支持。还有一个不同凡响的是,Media Queries在其余浏览器中不要像其余CSS3属性同样在不一样的浏览器中添加前缀

相关文章
相关标签/搜索