media queries 翻译过来就是媒体查询,media 指的媒体类型、那么有哪些类型呢,常用的有 screen(屏幕)、打印(print),个人理解就是它所在的不同终端。
常用的用法:
1,<link rel="stylesheet" media="screen and (max-width:600px)" href="small.css" />
根据符合的条件,调用相应的样式
2,在css中直接使用 媒体特性(判断条件)
Media query只接受单个的逻辑表达式作为其值,或者没有值;
我们把上面调用外部样式更改为css写法:
@media screen and (max-width:600px){
html { font-size:30px;}
}
max-width 表示小于等于某个宽度的时候
min-width 表示大于等于某个宽度的时候
更多属性值参考:
3,多个media queries(媒体特性) 使用
<link rel="stylesheet" media="screen and (min-width:600px) and (max-width:900px)" href="b.css" type="text/css" />
上面的的意思是在屏幕宽度大于等于600px、小于等于900px的时候,显示b.css 中的样式
4,设备屏幕的输出宽度 device width
<link rel="stylesheet" media="screen and (max-device-width: 480px)" href="iphone.css" type="text/css" />
上面的代码指的是iphone.css样式适用于最大设备宽度为480px,比如说iPhone上的显示,这里的max-device-width所指的是设备的实际分辨率,也就是指可视面积分辨率
个人理解:根据你终端设备的屏幕大小,来调用样式,不适合用于pc端
5,针对iphone4 设置样式
<link rel="stylesheet" media="only screen and (-webkit-min-device-pixel-ratio: 2)" type="text/css" href="iphone4.css" />
上面的样式是专门针对iPhone4的移动设备写的。
6,ipad
<link rel="stylesheet" media="all and (orientation:portrait)" href="portrait.css" type="text/css" /> <link rel="stylesheet" media="all and (orientation:landscape)" href="landscape.css" type="text/css" />
在大数情况下,移动设备iPad上的Safari和在iPhone上的是相同的,只是他们不同之处是iPad声明了不同的方向,比如说上面的例子, 在纵向(portrait)时采用portrait.css来渲染页面;在横向(landscape)时采用landscape.css来渲染页面。
7,android
/*240px的宽度*/ <link rel="stylesheet" media="only screen and (max-device-width:240px)" href="android240.css" type="text/css" /> /*360px的宽度*/ <link rel="stylesheet" media="only screen and (min-device-width:241px) and (max-device-width:360px)" href="android360.css" type="text/css" /> /*480px的宽度*/ <link rel="stylesheet" media="only screen and (min-device-width:361px) and (max-device-width:480px)" href="android480.css" type="text/css" />
我们可以使用media query为android手机在不同分辨率提供特定样式,这样就可以解决屏幕分辨率的不同给android手机的页面重构问题。
8,not 关键字
<link rel="stylesheet" media="not print and (max-width: 1200px)" href="print.css" type="text/css" />
not关键字是用来排除某种制定的媒体类型,换句话来说就是用于排除符合表达式的设备。
9,only 关键字
<link rel="stylesheet" media="only screen and (max-device-width:240px)" href="android240.css" type="text/css" />
only用来定某种特定的媒体类型,可以用来排除不支持媒体查询的浏览器。其实only很多时候是用来对那些不支持Media Query但却支持Media Type的设备隐藏样式表的。其主要有:支持媒体特性(Media Queries)的设备,正常调用样式,此时就当only不存在;对于不支持媒体特性(Media Queries)但又支持媒体类型(Media Type)的设备,这样就会不读了样式,因为其先读only而不是screen;另外不支持Media Qqueries的浏览器,不论是否支持only,样式都不会被采用。
10,在Media Query中如果没有明确指定Media Type,那么其默认为all,如:
<link rel="stylesheet" media="(min-width: 701px) and (max-width: 900px)" href="medium.css" type="text/css" />
另外还有使用逗号(,)被用来表示并列或者表示或,如下
<link rel="stylesheet" type="text/css" href="style.css" media="handheld and (max-width:480px), screen and (min-width:960px)" />
上面代码中style.css样式被用在宽度小于或等于480px的手持设备上,或者被用于屏幕宽度大于或等于960px的设备上。
解决问题:
所有的一切知识都是为了解决工作中遇到的问题,那么media queries 解决我们的什么问题呢?也就是在什么情况下要用到呢?我是在制作手机页面的根据屏幕大小来制定不同间距、字体大小,所用到的,同样它也可以指定响应式的页面。那么他的字体怎么设置呢?举个例子,在640px下,字体大小是38px,那么再480px终端下,字体大小就是 480/640*38 最后等于28.5px 。如果要得到准确的字体,我们需要随时的去计算,用js的方法我还没有做过,有空可以尝试下,但是通过css3的media queris 就可以解决我所遇到的问题。
但是如果在 iphone下字体显示的比较小,怎么办呢?(待续)
参考网址: