1、CSS3 实例教程:自适应的弹性布局Css3 引入了新的盒模型弹性盒模型,该模型决定一个盒子在其他盒子中的分布方式以及如何处理可用的空间。这与 XUL(火狐使用的用户交互语言)相似,其它语言也使用相同的盒模型,如 XAML 、GladeXML。使用该模型,可以很轻松的创建自适应浏览器窗口的流动布局或自适应字体大小的弹性布局。本文的例子使用以下的 HTML 代码:123传统的盒模型基于 HTML 流在垂直方向上排列盒子。使用弹性盒模型可以规定特定的顺序,也可以反转之。要开启弹性盒模型,只需设置拥有子盒子的盒子的display 的属性值为 box(或 inline-box)即可。display:
2、box;水平或垂直分布“box-orient”定义分布的坐标轴:vertical 和 horizional。这两个值定义盒子如何显示bodydisplay: box;box-orient: horizontal;反向分布“box-direction”可以设置盒子出现的顺序。默认情况下,只需定义分布坐标轴box 随 html 流分布。如果为水平坐标轴,则从左到右分布;垂直坐标轴则从上到下分布。定义“box-direction”的属性值为“reverse”,则反转盒子的排列顺序。body display: box;box-orient: vertical;box-direction: revers
3、e;具体分布属性“box-ordinal-group”定义盒子分布的顺序。可以随意的控制其分布顺序。这些组以一个从“1”开始的数字定义,盒模型将首先分布这些组,所有这些盒子将在每个组中。分布将从小到大排列。body display: box;box-orient: vertical;box-direction : reverse;#box1 box-ordinal-group: 2;#box2 box-ordinal-group: 2;#box3 box-ordinal-group: 1;盒子尺寸默认情况下,盒子并不具有弹性,如果 box-flex 的属性值至少为 1 时,则变得富有弹性。如果
4、盒子不具有弹性,它将尽可能的宽使其内容可见,且没有任何溢出,其大小由“width”和“height”来决定(或 min-height、min-width、max-width、max-height)。如果盒子是弹性的,其大小将按下面的方式计算:1. 具体的大小声明(width、height、min-width、min-height、max-width、max-height); 2. 父盒子的大小和所有余下的可利用的内部空间 如果盒子没有任何大小声明,那么其大小将完全取决于父 box 的大小。即:盒子的大小等于父级盒子的大小乘以其 box-flex 在所有子盒子 box-flex 总和中的百分比(
5、子盒子的大小=父盒子的大小*子盒子的 box-flex/所有子盒子的box-flex 值的和)。如果一个或更多的盒子有一个具体的大小声明,那么其大小将计算其中,余下的弹性盒子将按照上面的原则分享剩下的可利用空间。看看下面的例子,理解起来更容易。所有盒子都是弹性的下面的例子中,box1 的大小为 box2 的两倍,box2 与 box3 大小一样。看起来好像是用百分比定义盒子的大小,但是有一个区别:使用弹性盒模型,增加一个盒子,无须重新计算其大小。body display: box;box-orient: horizontal;#box1 box-flex: 2;#box2 box-flex:
6、1;#box3 box-flex: 1;一些盒子有固定大小下面的例子中,box3 并不是弹性的,宽度为 160px;这样 box1 和 box2 将有240px 的可利用空间。因此,box1 的宽度为 160px(240*2/3),box2 的宽度为80px(240*1/3)。body display: box;box-orient: horizontal;width: 400px;#box1 box-flex: 2;#box2 box-flex: 1;#box3 width: 160px;溢出管理因为是弹性盒子、非弹性盒子混排,有可能所有盒子的尺寸大于或小于父盒子的尺寸。这样就有可能空间太多
7、或空间不足。空间太多如何处理可利用空间的分布取决于两个属性值:box-align 和 box-pack。属性“box-pack”管理水平方向上的空间分布,有以下四个可能属性:start、end、 justify、 or center。1. start 所有盒子在父盒子的左侧,余下的空间在右侧; 2. end 所有盒子在父盒子的右侧,余下的空间在左侧; 3. justify 余下的空间在盒子间平均分配; 4. center 可利用的空间在父盒子的两侧平均分配。 属性“box- align”管理垂直方向上的空间分布,有以下五个可能属性之:start、 end,、center、 baseline 和
8、 stretch。1. start 每个盒子沿父盒子的上边缘排列,余下的空间位于底部; 2. end 每个盒子沿父盒子的下边缘排列,余下的空间位于顶部; 3. center 可用空间平均分配,上面一半,下面一半; 4. baseline 所有盒子沿着它们的基线排列,余下的空间可前可后; 5. stretch 每个盒子的高度调整到适合父盒子的高度 body display: box;box-orient: horizontal;width: 400px;#box1 box-flex: 2;#box2 box-flex: 1;#box3 width: 160px;空间不足怎么办与传统的盒模型一样,overflow 属性用来决定其显示方式。为了避免溢出,你可以设置 box-lines 为 multiple 使其换行显示。弹性盒模型看起来很不错,Gecko 和 WebKit 对该模型都有一些尝试性的测试。在这些属性之前加上-moz 和-webkit 即可使用该属性。也即是说,firefox、safari、chrome 可以使用这些特性,可以看看这个弹性盒模型的demo。作为前端开发者来说,该模型对我们解决网页设计中一些常见的问题非常方便,如:表单布局、垂直居中、视觉上分离 html 流,等等。不就的将来它将成为一个 web 标准,早早熟悉它不是什么坏事。