自适应阶段
自从有了不同屏幕的尺寸,我们就开始尝试自适应了
居中
虽然不能让所有屏幕都自适应,但是可以利用居中让元素看起来在同一位置
.center{
width: 990px;
margin: 0 auto;
height: 200px;
line-height: 200px;
}
百分比
可以利用百分比让DOM结构适应屏幕
.container{
border-top: solid 1px #666;
border-left: solid 1px #666;;
}
.item{
display: inline-block;
width: 33%;
height: 200px;
border-right: solid 1px #666;
border-bottom: solid 1px #666;
background: orange;
box-sizing: border-box;
}
浮动
对于宽度不一的,也可以利用浮动做到一定程度的自适应
.container{
overflow: hidden;
padding: 20px;
}
.item{
float: left;
padding: 8px 12px;
border: solid 1px #1686cc;
}
响应式
CSS3的Media Queries,可以针对不同的设备场景使用不同的CSS
媒体查询developer.mozilla.orgCSS 2
在很早之前,CSS就支持媒体查询了
页面有些部分需要在打印的时候隐藏或者变大,这时候可以使用media使某些style只在打印的时候生效
@media print {
/* 适用于印刷的样式 */
}
常用的媒体类型有
1. all(所有),适用于所有设备。
2. handheld(手持),用于手持设备。
3. print(印刷),用于分页材料以及打印预览模式下在屏幕上的文档视图。
4. projection(投影),用于投影演示文稿,例如投影仪。
5. screen(屏幕) ,主要用于计算机屏幕。
在使用的时候可以在样式表直接书写 @media指令+空格+媒体类型
(多个逗号隔开)
@media print {
body { font-size: 10pt }
}
@media screen {
body { font-size: 13px }parsing-errors
}
@media screen, print {
body { line-height: 1.2 }
}
CSS 3
但是CSS 2的媒体类型应用场景极为有限,CSS3大大拓展了这一能力
@media screen and (max-width: 990px){
.container{
background: orange;
}
}
当媒体类型匹配且表达式为真的时候,对应style就会其作用,除非使用not或者only操作符,否则媒体类型不是必需的,默认代表所有媒体类型。
媒体查询 media query
操作符
and
and操作符用于将多个media feature组合成一个查询,同时用于组合media type 和media feature,一个基本的media query类似这样,一个meidia feature作用于所有media type
@media (min-width: 700px) { ... }
但是如果只想在横向显示时应用就可以使用and操作符把media type和media feature结合起来
@media (min-width: 700px) and (orientation: landscape) { ... }
这样上面的media query只有在可视窗口(viewport)最小是700px并且是横向显示的时候才返回true,如果还想进一步限制设备为tv可以这样
@media tv and (min-width: 700px) and (orientation: landscape) { ... }
- 逗号分隔的列表
在使用逗号分隔的查询列表中每个查询都被视为一个独立的查询,任何本查询中的作用符不影响其他查询,只要有一个查询返回true,style就会被作用。
举例来说,如果希望特定style在viewport最小宽度为700px或手持式设备上生效,可以这么写:
@media (min-width: 700px), handheld and (orientation: landscape) { ... }
not
not操作符作用于整个查询,所以只有在整个查询返回false
的情况下使用not后才会返回true
。当使用逗号分隔的列表的时候not作用于邻近的查询,而不会作用于每个查询
@media not all and (monochrome) { ... }
查询其实会这样起作用
@media not (all and (monochrome)) { ... }
而不是这样
@media (not all) and (monochrome) { ... }
对于逗号分隔的列表
@media not screen and (color), print and (color)
查询是这样子的
@media (not (screen and (color))), print and (color)
only
only操作符用于阻止不支持带有media feature的media queries的浏览器应用特定style
<link rel="stylesheet" media="only screen and (color)" href="example.css" />
media features
有以下常用的media feature:
- width:浏览器宽度
- height:浏览器高度
- device-width:设备屏幕分辨率的宽度值
- device-height:设备屏幕分辨率的高度值
- orientation:浏览器窗口的方向纵向还是横向,当窗口的高度值大于等于宽度时该特性值为portrait,否则为landscape
- aspect-ratio:比例值,浏览器的纵横比
- device-aspect-ratio:比例值,屏幕的纵横比
- color:设备使用多少位的颜色值,如果不是彩色设备,值为0
- color-index:色彩表的色彩数
- monochrome:单色帧缓冲器每个像素的字节
- resolution:分辨率值,设备分辨率值
- scan:电视机类型设备扫描方式,progressive或interlace
- grid:只能指定两个值0或1,是否基于栅格的设备
引入媒体查询 media
link方法引入
<link rel="stylesheet" type="text/css" href="styleB.css" media="screen and (min-width: 600px) and (max-width: 800px)">
@media引入
@media screen and (min-width: 600px) and (max-width: 800px){
选择器{
属性:属性值;
}
}
浏览器兼容性
Can I use... Support tables for HTML5, CSS3, etccaniuse.com代码示例:
JS Binjs.jirengu.com!注意事项:
- 使用 min-width/height和 max-width/height
- 注意选择器权重优先级,后面的样式会覆盖前面的样式
参考
- http://www.w3cplus.com/content/css3-media-queries
2. http://www.w3cplus.com/css3/css3-media-queries-for-iPhone-and-iPads
3. https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Media_queries
移动端初探(手机页面)
代码示例
JS Binjs.jirengu.com使用媒体查询 @media语法所写
在pc上:
控制台手机模拟:
模拟各种型号手机:
meta viewport
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
width
设置layout viewport的宽度,为一个正整数,或字符串"width-device"
initial-scale
设置页面的初始缩放值,为一个数字,可以带小数minimum-scale
允许用户的最小缩放值,为一个数字,可以带小数maximum-scale
允许用户的最大缩放值,为一个数字,可以带小数height
设置layout viewport的高度,这个属性对我们并不重要,很少使用user-scalable
是否允许用户进行缩放,值为"no"或"yes", no 代表不允许,yes代表允许
手机页面总结:
- 学会媒体查询 media query
- 学会隐藏元素
- 手机端要加一个 meta
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
- 手机端的交互方式与PC不一样
- 设计好才做,不然页面丑
- 推荐使用 flex布局