在css2
中就有media type
属性,用于判断媒体类型。
在css3
中新增了 media query
属性用于增强media type
属性。
因此当css3
问世后,这个问题有了新的解决办法。media query
属性的是media type
属性的增强功能,使media type
可以进行条件判断输出对应的css
。
media query的使用方法
一、判断媒体类型,引用不同的样式表
<link rel=”stylesheet” media=”screen and (判断条件)” herf=”需要调用的样式表文件” />
通过设定屏幕的判断条件,调用对应的css
文件。该实例多用于整页面不同风格的css
调用与选取,使用该方法可能需要为一个页面制作多份个css
文件。
二、判断媒体类型,执行不同的css样式属性
@media screen and (max-width:240px){
.box{width:200px;}
.title{color:red;}
}
上述实例可以出现在外部样式表与内部样式表中。直接在样式表中以@media screen
属性标注媒体类型的判断事件,在括号中写出判断条件为max-width:240px;
该判断的意思是屏幕宽度不超过240px则执行大括号内的样式属性。
前端开拓者做了@media screen
相应的判断尝试,并在首页与文章列表页加入了@media screen
的功能实例。判断样式书写如下:
@media screen and (min-width:1200px){.post_box{width: 45%;float: left;}.c-con{height:140px;}}
如果用户使用分辨率宽度大于1200px的浏览器访问网站,则页面呈现为三栏模式,如下图:
如果分辨率小于1200px则页面会呈现为两栏模式,如下图:
建议在使用判断时,如果只是在样式表内进行判断的话,可以修改部分重要样式来达到修改布局的目的。
通过@media screen
与width
条件判断,可以事先对页面的宽度进行策划,然后根据不同的页面宽度设定不同的css
样式,有效的控制web
页面在各种分辨率下的样式表先。
注意:
在使用@media screen
与width
时,需要在html文档中加入<meta>
标签,内容如下:
<meta name="viewport" content="width=device-width,initial-scale=1.0">
否则在移动端可能不会实现你想要的效果;
这一段html
代码是什么意思呢?
name
为键,键值为viewport
。content
为值,为"width=device-width,initial-scale=1.0"
其中
width=device-width 表示可视区域的宽度为设备宽度(手机或pc)
initial-scale=1.0 表示页面首次被显示时,按实际尺寸显示,无任何缩放。