css弹性布局是什么

html-css012

css弹性布局是什么,第1张

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

您好,你要求的是指定css3盒子布局的垂直居中

1.首先是要使盒子为display:box | -webkit-box| -moz-box

2.设置元素的box-pack和box-align即可,这两个属性当前只有webkit和moz支持。

3.box-pack控制的是水平的左和右,取值有:start(居左),center(居中),end(居右)。

4.box-align的取值有:start(居上),center(居中),end(居下)。

如果我们要设置垂直居中的话只需要将这两个属性的值都设置为center即可

这样:

body{ margin:0padding:0width:100%

height:100%

} div{ position:absolutetop:50%left:50%margin-top:-250px margin-left:-250px/*此时宽和高都要固定*/ width:500pxheight:500px} body{

margin:0

padding:0

width:100%

height:100%

}

div{

position:absolute

top:50%

left:50%

margin-top:-250px

margin-left:-250px

/*此时宽和高都要固定*/

width:500px

height:500px

}

扩展资料:

注意事项

一、用两个值就可以了

1、text-align:center

//这是让文字左右居中

2、line-height:100px

//这是让文字垂直居中

vertical-align:middle

//这个属性不能让文字垂直居中,该属性定义行内元素的基线相对于该元素所在行的基线的垂直对齐。允许指定负长度值和百分比值。这会使元素降低而不是升高。在表单元格中,这个属性会设置单元格框中的单元格内容的对齐方式。

二、多行文本垂直居中分为两种情况,一个是父级元素高度不固定,随着内容变化;另一个是父级元素高度固定。

1、父级元素高度不固定

父级高度不固定的时,高度只能通过内部文本来撑开。可以通过设置内填充(padding)的值来使文本看起来垂直居中,只需设置padding-top和padding-bottom的值相等:

<!--html代码-->

  <div id="div1">

          这是多行文本垂直居中,

          这是多行文本垂直居中,

          这是多行文本垂直居中,

          这是多行文本垂直居中。

  </div>

/*css代码*/

      #div1{

          width: 300px

          margin: 50px auto

          border: 1px solid red

          text-align: center/*设置文本水平居中*/

          padding: 50px 20px

      }

2、父级元素高度固定

只对拥有valign特性的元素才生效,结合display: table,可以使得div模拟table属性。因此可以设置父级div的display属性:display: table;然后再添加一个div包含文本内容,设置其display:table-cell和vertical-align:middle。