html弹性盒⼦垂直排列,css3弹性盒⼦布局
css3弹性盒⼦布局
CSS3 弹性盒( Flexible Box 或 flexbox),是⼀种当页⾯需要适应不同的屏幕⼤⼩以及设备类型时确保元素拥有恰当的⾏为的布局⽅式。
引⼊弹性盒布局模型的⽬的是提供⼀种更加有效的⽅式来对⼀个容器中的⼦元素进⾏排列、对齐和分配空⽩空间。
display:flex和display:box都可⽤于弹性布局,不同的是display:box是2009年的命名,已经过时,⽤的时候需要加上前缀;display:flex 是2012年之后的命名。在实际的测试中display:flex不能完全的替代display:box。display:flex的浏览器兼容性⽐较⿇烦。
1.关于display:flex
对于PC端,⼀般chrome和⽕狐都能很好地⽀持。ie不⽀持,显⽰的是顺序排列下来的宽度100%的模块。
对于移动端:
(1)上述代码iOS的原⽣safari浏览器是⽀持的;UC浏览器⽀持的很好;浏览器不⽀持
(2)安卓的原⽣浏览器不⽀持,能够正常显⽰模块,⽂档流依次排列;UC浏览器不⽀持,显⽰为空⽩;浏览器不⽀持
2.关于display:box
PC端:chrome和⽕狐都能很好地⽀持。ie不⽀持,显⽰的是顺序排列下来的宽度100%的模块。
移动端:
(1)上述代码iOS的原⽣safari浏览器是⽀持的;UC浏览器⽀持的很好
(2)安卓的原⽣浏览器⽀持;UC浏览器不⽀持,显⽰为空⽩
总的来说,不考虑IE浏览器的话,PC端上使⽤哪个都可以,⼀般使⽤display:flex;移动端的安卓的UC只⽀持display:box,iOS的UCdisplay:box和display:flex两个都⽀持。
兼容浏览器的写法
display: -webkit-box; /* Chrome 4+, Safari 3.1, iOS Safari 3.2+ */
display: -moz-box; /* Firefox 17- */
display: -webkit-flex; /* Chrome 21+, Safari 6.1+, iOS Safari 7+, Opera 15/16 */
display: -moz-flex; /* Firefox 18+ */
display: -ms-flexbox; /* IE 10 */
display: flex; /* Chrome 29+, Firefox 22+, IE 11+, Opera 12.1/17/18, Android 4.4+ */
先介绍⼀下display:box 的写法
1.box-align:start/end/center/baseline/stretch
在⽗级设置,⼦代的垂直对齐⽅式。
start
对于正常⽅向的框,每个⼦元素的上边缘沿着框的顶边放置。
对于反⽅向的框,每个⼦元素的下边缘沿着框的底边放置。
end
对于正常⽅向的框,每个⼦元素的下边缘沿着框的底边放置。
对于反⽅向的框,每个⼦元素的上边缘沿着框的顶边放置。
center
均等地分割多余的空间,⼀半位于⼦元素之上,另⼀半位于⼦元素之下。
baseline
如果 box-orient 是inline-axis或horizontal,所有⼦元素均与其基线对齐。
stretch
拉伸⼦元素以填充包含块,与⽗级设置的⾼度⼀致。⼦代height⽆效。
-webkit-box-align:center;
box-align:center;
2.box-pack:start/end/center/justify
在⽗级设置,⼦代的⽔平对齐⽅式。
start
对于正常⽅向的框,⾸个⼦元素的左边缘被放在左侧(最后的⼦元素后是所有剩余的空间)
对于相反⽅向的框,最后⼦元素的右边缘被放在右侧(⾸个⼦元素前是所有剩余的空间)
end
对于正常⽅向的框,最后⼦元素的右边缘被放在右侧(⾸个⼦元素前是所有剩余的空间)。
对于相反⽅向的框,⾸个⼦元素的左边缘被放在左侧(最后⼦元素后是所有剩余的空间)。center
均等地分割多余空间,其中⼀半空间被置于⾸个⼦元素前,另⼀半被置于最后⼀个⼦元素后justify
在每个⼦元素之间分割多余的空间(⾸个⼦元素前和最后⼀个⼦元素后没有多余的空间)。
-webkit-box-pack:center;
box-pack:center;
3.box-orient:horizontal|vertical|inline-axis|block-axis|inheritflex布局对齐方式
horizontal
在⽔平⾏中从左向右排列⼦元素
vertical
从上向下垂直排列⼦元素
inline-axis
沿着⾏内轴来排列⼦元素(映射为 horizontal)
block-axis
沿着块轴来排列⼦元素(映射为 vertical)
inherit
应该从⽗元素继承 box-orient 属性的值。
-webkit-box-orient:vertical;
box-orient:vertical;
4.box-direction: normal|reverse|inherit;
normal
以默认⽅向显⽰⼦元素
reverse
以反⽅向显⽰⼦元素
inherit
应该从⼦元素继承 box-direction 属性的值
5.box-flex:number;
1)占⽗级元素宽度的number份
2)若⼦元素设置固定宽度,则该⼦元素应⽤固定宽度,其他未设置固定宽度的字元素将余下的⽗级宽度(⽗级-已设置固定宽度的⼦代元素的总宽度按 number占份数
3)若⼦元素有margin值,则按余下(⽗级宽度-⼦代固定总宽度-总margin值)宽度占number份
下⾯介绍⼀下display 属性的值为 flex 或 inline-flex的写法
常⽤属性有
flex-direction
指定弹性容器中⼦元素排列⽅式
flex-wrap
设置弹性盒⼦的⼦元素超出⽗容器时是否换⾏
flex-flow
flex-direction 和 flex-wrap 的简写
align-items
设置弹性盒⼦元素在侧轴(纵轴)⽅向上的对齐⽅式
align-content
修改 flex-wrap 属性的⾏为,类似 align-items, 但不是设置⼦元素对齐,⽽是设置⾏对齐
justify-content
设置弹性盒⼦元素在主轴(横轴)⽅向上的对齐⽅式
1. flex-direction 属性
flex-direction: row | row-reverse | column | column-reverse;
row
默认值。元素将⽔平显⽰,正如⼀个⾏⼀样。
row-reverse
与 row 相同,但是以相反的顺序。
column
元素将垂直显⽰,正如⼀个列⼀样。
column-reverse
与 column 相同,但是以相反的顺序。
2. flex-wrap 属性
flex-wrap: nowrap | wrap | wrap-reverse;
nowrap
默认值。规定元素不拆⾏或不拆列。
wrap
规定元素在必要的时候拆⾏或拆列。
wrap-reverse
规定元素在必要的时候拆⾏或拆列,但是以相反的顺序。
3. flex-flow 属性
flex-flow属性是flex-direction属性和flex-wrap属性的简写形式,默认值为row nowrap。flex-flow:
4. align-items属性
align-items 属性定义flex⼦项在flex容器的当前⾏的侧轴(纵轴)⽅向上的对齐⽅式。stretch
默认值。项⽬被拉伸以适应容器。
center
项⽬位于容器的中⼼。
flex-start
项⽬位于容器的开头。
flex-end
项⽬位于容器的结尾。
baseline
项⽬位于容器的基线上。
5. justify-content属性
justify-content ⽤于设置或检索弹性盒⼦元素在主轴(横轴)⽅向上的对齐⽅式。
flex-start
默认值。项⽬位于容器的开头。
flex-end
项⽬位于容器的结尾。
center
项⽬位于容器的中⼼。
space-between
项⽬位于各⾏之间留有空⽩的容器内。
space-around
项⽬位于各⾏之前、之间、之后都留有空⽩的容器内。
弹性⼦元素属性
order
设置弹性盒⼦的⼦元素排列顺序。
flex-grow
设置或检索弹性盒⼦元素的扩展⽐率。
flex-shrink
指定了 flex 元素的收缩规则。flex 元素仅在默认宽度之和⼤于容器的时候才会发⽣收缩,其收缩的⼤⼩是依据 flex-shrink 的值。flex-basis
⽤于设置或检索弹性盒伸缩基准值。
flex
设置弹性盒⼦的⼦元素如何分配空间。
align-self
在弹性⼦元素上使⽤。覆盖容器的 align-items 属性。
1. order属性
order: ;
⽤整数值来定义排列顺序,数值⼩的排在前⾯。可以为负值,默认为0。
2. flex-grow属性
flex-grow: ;
integer:⼀个数字,规定项⽬将相对于其他灵活的项⽬进⾏扩展的量。默认值是 0。
3. flex-shrink属性
flex-shrink: ;
integer:⼀个数字,规定项⽬将相对于其他灵活的项⽬进⾏收缩的量。默认值是 1。
4. flex-basis属性
flex-basis: | auto;
integer:⼀个长度单位或者⼀个百分⽐,规定元素的初始长度。
auto:默认值。长度等于元素的长度。如果该项⽬未指定长度,则长度将根据内容决定。
5. flex属性
flex 属性⽤于设置或检索弹性盒模型对象的⼦元素如何分配空间。
flex 属性是 flex-grow、flex-shrink 和 flex-basis 属性的简写属性
flex: flex-grow flex-shrink flex-basis | auto | initial | inherit;

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。