首页
TVP 最新优惠活动
学习
活动
专区
工具
返回腾讯云官网
目前在不考虑IE以及低端安卓机(4.3-)的兼容下,已经可以放心使用flex进行布局了。什么是flex布局以及它的好处,这里就不再赘述。
在这篇文章里,想说说flex布局的属性语法及其细节。那么网上也有不少flex布局的教程,为什么又要再写一篇?
首先,flex布局的迷之属性们,如果一知半解,机械记忆的话,那不到半个月基本忘光光。先感受一下这12个flex布局属性,是不是很“迷”人。
容器属性
元素属性
就连老外也都在twitter吐槽不好理解,可见还是有一定的学习成本。
而目前很多flex教程主要以列举属性为主,缺乏对比和理解性脉络。
因此,下面会通过我梳理的一个脉络去理解flex布局,包括不同属性的异同以及一些容易造成误解的细节点,彻底弄懂flex布局。
对于某个元素只要声明了display: flex;
,那么这个元素就成为了弹性容器,具有flex弹性布局的特性。
display:flex
设置为另一个弹性容器,形成嵌套关系。因此一个元素既可以是弹性容器也可以是弹性元素。弹性容器的两根轴非常重要,所有属性都是作用于轴的。下面从轴入手,将所有flex布局属性串起来理解。
flex布局是一种一维布局模型,一次只能处理一个维度(一行或者一列)上的元素布局,作为对比的是二维布局 CSS Grid Layout,可以同时处理行和列上的布局。
也就是说,flex布局大部分的属性都是作用于主轴的,在交叉轴上很多时候只能被动地变化。
我们可以在弹性容器上通过flex-direction
修改主轴的方向。如果主轴方向修改了,那么:
弹性元素永远沿主轴排列,那么如果主轴排不下,该如何处理?
通过设置flex-wrap: nowrap | wrap | wrap-reverse
可使得主轴上的元素不折行、折行、反向折行。
默认是nowrap
不折行,难道任由元素直接溢出容器吗?当然不会,那么这里就涉及到元素的弹性伸缩应对,下面会讲到。
wrap
折行,顾名思义就是另起一行,那么折行之后行与行之间的间距(对齐)怎样调整?这里又涉及到交叉轴上的多行对齐。
wrap-reverse
反向折行,是从容器底部开始的折行,但每行元素之间的排列仍保留正向。
flex-flow = flex-drection + flex-wrap
flex-flow
相当于规定了flex布局的“工作流(flow)”
flex-flow: row nowrap;
当flex-wrap: nowrap;
不折行时,容器宽度有剩余/不够分,弹性元素们该怎么“弹性”地伸缩应对?
这里针对上面两种场景,引入两个属性(需应用在弹性元素上)
flex-shrink
:缩小比例(容器宽度<元素总宽度时如何收缩)flex-grow
:放大比例(容器宽度>元素总宽度时如何伸展)来看下以下场景,弹性容器#container
宽度是200px,一共有三个弹性元素,宽度分别是50px、100px、120px。在不折行的情况下,此时容器宽度是明显不够分配的。
实际上,flex-shrink
默认为1,也就是当不够分配时,元素都将等比例缩小,占满整个宽度,如下图。
#container {
display: flex;
flex-wrap: nowrap;
}
真的是等比缩小(每个元素各减去70/3的宽度)吗?这里稍微深究一下它的收缩计算方法。
先抛结论:flex-shrink: 1
并非严格等比缩小,它还会考虑弹性元素本身的大小。
-70px
1*50 + 1*100 + 1*120 = 270
(1为各元素flex-shrink的值)1*50/270
1*50/270 * (-70)
50px + (1*50/270 *(-70)) = 37.03px
加入弹性元素本身大小作为计算方法的考虑因素,主要是为了避免将一些本身宽度较小的元素在收缩之后宽度变为0的情况出现。
同样,弹性容器#container
宽度是200px,但此时只有两个弹性元素,宽度分别是50px、100px。此时容器宽度是有剩余的。
那么剩余的宽度该怎样分配?而flex-grow
则决定了要不要分配以及各个分配多少。
(1)在flex布局中,容器剩余宽度默认是不进行分配的,也就是所有弹性元素的flex-grow
都为0。
(2)通过指定flex-grow
为大于零的值,实现容器剩余宽度的分配比例设置。
放大的计算方法并没有与缩小一样,将元素大小纳入考虑。
仅仅按flex-grow
声明的份数算出每个需分配多少,叠加到原来的尺寸上。
50px
50px / (3+2) = 10px
50px + 3 * 10 = 80px
下图中,弹性容器的宽度正好等于元素宽度总和,无多余宽度,此时无论flex-grow
是什么值都不会生效。
同理,对于flex-shrink
,在容器宽度有剩余时也是不会生效的。因此这两个属性是针对两种不同场景的互斥属性。
在进行弹性处理之余,其实有些场景我们更希望元素尺寸固定,不需要进行弹性调整。设置元素尺寸除了width和height以外,flex还提供了一个flex-basis
属性。
flex-basis
设置的是元素在主轴上的初始尺寸,所谓的初始尺寸就是元素在flex-grow
和flex-shrink
生效前的尺寸。
首先以width为例进行比较。看下下面的例子。#container {display:flex;}
。
<div id="container">
<div>11111</div>
<div>22222</div>
</div>
—— 数值相同时两者等效
—— 同时设置,flex-basis优先级高
flex-basis为auto时,如设置了width则元素尺寸由width决定;没有设置则由内容决定
这个属性应该是最容易迷糊的一个,下面揭开它的真面目。
flex = flex-grow + flex-shrink + flex-basis
复合属性,前面说的三个属性的简写。
flex: 1
= flex: 1 1 0%
flex: 2
= flex: 2 1 0%
flex: auto
= flex: 1 1 auto;
flex: none
= flex: 0 0 auto;
// 常用于固定尺寸 不伸缩其实可以归结于flex-basis:0
和flex-basis:auto
的区别。
flex-basis
是指定初始尺寸,当设置为0时(绝对弹性元素),此时相当于告诉flex-grow
和flex-shrink
在伸缩的时候不需要考虑我的尺寸;相反当设置为auto
时(相对弹性元素),此时则需要在伸缩时将元素尺寸纳入考虑。
因此从下图(转自W3C)可以看到绝对弹性元素如果flex-grow
值是一样的话,那么他们的尺寸一定是一样的。
前面讲完了元素大小关系之后,下面是另外一个重要议题——如何对齐。可以发现上面的所有属性都是围绕主轴进行设置的,但在对齐方面则不得不加入作用于交叉轴上。需要注意的是这些对齐属性都是作用于容器上。
justify-content
主轴上比较好理解,重点是交叉轴上。因为交叉轴上存在单行和多行两种情况。
align-items
默认值是stretch
,当元素没有设置具体尺寸时会将容器在交叉轴方向撑满。
当align-items
不为stretch
时,此时除了对齐方式会改变之外,元素在交叉轴方向上的尺寸将由内容或自身尺寸(宽高)决定。
注意,交叉轴不一定是从上往下,这点再次强调也不为过。
还记得可以通过flex-wrap: wrap
使得元素在一行放不下时进行换行。在这种场景下就会在交叉轴上出现多行,多行情况下,flex布局提供了align-content
属性设置对齐。
align-content
与align-items
比较类似,同时也比较容易迷糊。下面会将两者对比着来看它们的异同。
首先明确一点:align-content
只对多行元素有效,会以多行作为整体进行对齐,容器必须开启换行。
align-content: stretch | flex-start | flex-end | center | space-between | space-around
align-items: stretch | flex-start | flex-end | center | baseline
在属性值上,align-content
比align-items
多了两个值:space-between
和space-around
。
与align-items
一样,align-content:
默认值也是stretch
。两者同时都为stretch
时,毫无悬念所有元素都是撑满交叉轴。
#container {
align-items: stretch;
align-content: stretch;
}
当我们将align-items改为flex-start
或者给弹性元素设置一个具体高度,此时效果是行与行之间形成了间距。
#container {
align-items: flex-start;
align-content: stretch;
}
/*或者*/
#container {
align-content: stretch;
}
#container > div {
height: 30px;
}
为什么?因为align-content
会以整行为单位,此时会将整行进行拉伸占满交叉轴;而align-items
设置了高度或者顶对齐,在不能用高度进行拉伸的情况下,选择了用间距。
尝试把align-content
设置为顶对齐,此时以行为单位,整体高度通过内容撑开。
而align-items
仅仅管一行,因此在只有第一个元素设置了高度的情况下,第一行的其他元素遵循align-items: stretch
也被拉伸到了50px。而第二行则保持高度不变。
#container {
align-items: stretch;
align-content: flex-start;
}
#container > div:first-child {
height: 50px;
}
两者的区别还是不明显?来看下面这个例子。
这里仅对第二个元素的高度进行设置,其他元素高度则仍保持内容撑开。
以第一个图为例,会发现align-content
会将所有行进行顶对齐,然后第一行由于第二个元素设置了较高的高度,因此体现出了底对齐。
两者差异总结:
除了在容器上设置交叉轴对齐,还可以通过align-self
单独对某个元素设置交叉轴对齐方式。
align-items
相同align-items
属性auto
,表示继承父元素的align-items
属性#container {
display: flex;
align-items: flex-start;
}
#container > div:first-child {
align-self: stretch;
}
#container > div:nth-child(3) {
align-self: center;
}
#container > div:nth-child(4) {
align-self: flex-end;
}
#container > div:first-child {
order: 2;
}
#container > div:nth-child(2) {
order: 4;
}
#container > div:nth-child(3) {
order: 1;
}
#container > div:nth-child(4) {
order: 3;
}
order:可设置元素之间的排列顺序
参考阮老师博文中的骰子练习,我做了张图,大家不妨可以各自实现下,理解之后应该能够比较轻松地写出来。 codepen
Flex 布局教程:语法篇
Flex 布局教程:实例篇
flex code pen
理解Flexbox:你需要知道的一切
深入理解css3中的flex-grow、flex-shrink、flex-basis
A Complete Guide to Flexbox
flex实战及坑总结
flex bugs集锦
本文中未标明转载的图均属于原创,引用转载请注明来源。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
玻璃钢生产厂家绍兴玻璃钢雕塑摆件供货商四川玻璃钢雕塑摆件销售企业石岐区街道公园玻璃钢花盆厂家陕西景观玻璃钢雕塑玻璃钢雕塑摆放环境大庆小区玻璃钢雕塑厂家玻璃钢道教雕塑制作连云港玻璃钢海豚雕塑价格关于商场美陈的教程乐高玻璃钢雕塑鹰潭户内玻璃钢雕塑哪家便宜湖南玻璃钢仿真水果雕塑定制宝鸡广场标识校园玻璃钢雕塑公司公仔玻璃钢雕塑服务电话资兴玻璃钢卡通雕塑三门峡市玻璃钢雕塑玻璃钢雕塑怎么弄吉安水果玻璃钢雕塑市场内蒙古玻璃钢雕塑设计复原户外玻璃钢人物雕塑服务电话下城区玻璃钢雕塑公司上海周年庆典商场美陈供应江苏卡通玻璃钢动物鹤雕塑娄底玻璃钢雕塑制作荆门玻璃钢雕塑定做上海特色商场美陈多少钱阿坝玻璃钢群马雕塑常见玻璃钢花盆有哪些庆阳人物玻璃钢雕塑哪家好同安园林玻璃钢雕塑推荐香港通过《维护国家安全条例》两大学生合买彩票中奖一人不认账让美丽中国“从细节出发”19岁小伙救下5人后溺亡 多方发声单亲妈妈陷入热恋 14岁儿子报警汪小菲曝离婚始末遭遇山火的松茸之乡雅江山火三名扑火人员牺牲系谣言何赛飞追着代拍打萧美琴窜访捷克 外交部回应卫健委通报少年有偿捐血浆16次猝死手机成瘾是影响睡眠质量重要因素高校汽车撞人致3死16伤 司机系学生315晚会后胖东来又人满为患了小米汽车超级工厂正式揭幕中国拥有亿元资产的家庭达13.3万户周杰伦一审败诉网易男孩8年未见母亲被告知被遗忘许家印被限制高消费饲养员用铁锨驱打大熊猫被辞退男子被猫抓伤后确诊“猫抓病”特朗普无法缴纳4.54亿美元罚金倪萍分享减重40斤方法联合利华开始重组张家界的山上“长”满了韩国人?张立群任西安交通大学校长杨倩无缘巴黎奥运“重生之我在北大当嫡校长”黑马情侣提车了专访95后高颜值猪保姆考生莫言也上北大硕士复试名单了网友洛杉矶偶遇贾玲专家建议不必谈骨泥色变沉迷短剧的人就像掉进了杀猪盘奥巴马现身唐宁街 黑色着装引猜测七年后宇文玥被薅头发捞上岸事业单位女子向同事水杯投不明物质凯特王妃现身!外出购物视频曝光河南驻马店通报西平中学跳楼事件王树国卸任西安交大校长 师生送别恒大被罚41.75亿到底怎么缴男子被流浪猫绊倒 投喂者赔24万房客欠租失踪 房东直发愁西双版纳热带植物园回应蜉蝣大爆发钱人豪晒法院裁定实锤抄袭外国人感慨凌晨的中国很安全胖东来员工每周单休无小长假白宫:哈马斯三号人物被杀测试车高速逃费 小米:已补缴老人退休金被冒领16年 金额超20万