点击上方 前端Q,关注公众号

回复加群,加入前端Q技术交流群

来源 | https://www.cnblogs.com/wanglinmantan/p/15092001.html

flex全称Flexible Box模型,顾名思义就是灵活的盒子,不过一般都叫弹性盒子,所有PC端及手机端现代浏览器都支持,所以不用担心它的兼容性,有了这玩意,妈妈再也不用担心我们的布局。

先简单介绍一下,要使用flex布局,需要先给一个容器元素设置display:flex让它变成flex容器。

然后其所有的直接子元素就变成flex子元素了,在flex里存在两根轴,叫主轴和交叉轴,互相垂直,主轴默认水平,flex子元素默认会沿主轴排列,可以控制flex子元素在主轴上伸缩,主轴方向可以设置,相关的css属性分为两类,一类是给flex容器设置的,一类是给flex子元素设置的,本文在介绍一些典型场景实现的同时也会顺带讲解部分属性,当然更详细的内容可以阅读MDN上的教程。

单列布局

单列布局是最简单的布局了,从上到下排列,如图:

可以使用三个div来表示头、内容和尾,然后把外层容器,即body设为flex容器,因为flex默认的主轴是水平的,我们需要把它设置为垂直的,然后再设置元素在交叉轴居中即可:

当然更常见的情况是内容高度不确定,这样我们往往会希望在内容高度不满一屏时底部内容挨着底边,超过一屏时跟在最后,这首先需要容器元素有固定的高度,否则何来底边,我们可以把html和body的高度都设为100%,然后去掉给content元素设置的高度,并给它添加一个带高度的子元素:

接下来需要使用到flex-grow属性,这个是flex子元素上的属性,用来控制容器还有空间剩余时,flex子元素怎么进行扩展,默认值是0,也就是不扩展,子元素会显示为它们默认的大小,这个所谓的默认大小分几种情况:

1、如果子元素的另一个属性flex-basis设置了不为auto的具体数值,那么无论元素有没有设置具体大小都显示为该属性定义的尺寸;

2、如果子元素的flex-basis的值为auto(默认值),那么如果元素设置了具体的大小那么显示为该设置的尺寸;

3、否则取决于元素内容的max-content大小;

当flex-grow设为一个正数时,那么各个子元素会按设置的份数来按比例分配剩余可用的空间,比如剩余空间为90px,三个子元素该属性值都设为1,那么每个元素将在原来大小的基础上加上90/3=30px。

根据上述原理,我们只需要给content元素的flex-grow属性设为1即可,其他都是0,所以剩余空间将全给content元素:

这样内容不足时底部就可以挨着底边了,但是当内容过多,超过一屏时:

可以看到头和尾都没了,这是因为flex-shrink的原因,这个也是flex子元素上的属性,用来控制当子元素的尺寸之和已经超过容器了要怎么收缩元素,默认值为1,就是按比例减去要收缩的空间,理论上是这样,但实际上并没有这么简单,接下来简单测试一下:

容器元素body为800px高,上中下高度分别为100+1000+100=1200px,根据1:1:1的flex-shrink计算总权重为1*100+1*1000+1*100=1200,子元素总高度超过容器400px,这多出的要按的比例从各自高度中减去,具体为:

(400*1*100)/1200=33.33px(400*1*1000)/1200=333.33px(400*1*100)/1200=33.33px

也就是分别都减去上述值,减完后理论上各自的高度变成了66.67px、666.67.67px、66.67px,但是实际上:

可以看到头和尾都变成了0,内容高度没有变,这是为啥呢?上面我们提到了max-content,同样,这里对应着min-content的概念,虽然正常来说应该变成我们计算出的尺寸才对,但是减少到元素内容的min-content后它就不会再变小了。

content元素有个高度为1000的子元素,这个高度就是它的min-content,所以它不会缩小,它一个元素就比容器元素高了,再加上头和尾因为都没有内容,所以虽然理论上它们不是为0的。

但是为了更好的显示效果,浏览器就直接把它们减少到0了,我们可以随便给头和尾加一点文字,文字的高度就会变成它们的min-content,它们的高度也就不会变成0:

所以这就意味着不要想着去精确计算,把它交给浏览器,浏览器会给你以最好的方式呈现。

那么解决头和尾不要消失的问题很简单,可以给它们也加个固定高度的子元素,但是最简单的方法是把它们的flex-shrink设为0,也就是不收缩:

这样就实现我们的需求了。

经典导航栏

如图所示是一个经典的网站导航栏的布局,logo和导航在左,用户信息在右,不用flex可能会使用浮动,上图使用浮动还好,但是如果右边是两个块,那么右边浮动的元素的显示顺序和书写顺序要不一致才行,或者再用一个元素包裹一下,使用flex则没有这种烦恼。

该场景可以使用一个容器来包裹左边的logo和导航,再设置justify-content:space-between来实现,但是有个小技巧可以不用这个包裹元素,就是利用margin的auto值。

回忆一下我们以前水平居中都是怎么做的,是不是这样margin:0 auto,margin-left和margin-right的默认值是0,如果设置为auto,将会根据剩余可用空间来计算,这也是为什么能水平居中。

因为左右都想尽量多,那么就只能平分了,对于本示例,我们只给用户名flex子元素设置margin-left:auto,那么剩余空间将全部给它,也就相当于把用户块挤到右边去了:

隔行交叉显示

有时候为了不让布局太单调,即使一个列表是同类数据,展示上也会做成上述隔行交叉的样式,这个使用flex可以轻松的做到,给2n的行设置flex-direction: row-reverse即可让偶数行的主轴方向由默认的从左向右变成从右向左:

此外也可以使用order属性,这个属性可以让flex子元素按order的数值大小来排序显示,我们可以默认左边的设为2,右边的设为3,然后在偶数行再给右边的设为1,自然就跑到前面去了:

网格布局

此网格非grid布局,虽然网格列表用grid是最好的,但是本文的主角是flex,假设我们要实现下面这样一个列表:

上述列表对flex来说是不擅长的,因为要带间距,所以不能简单的把子元素宽度设为25%,否则再加上外边距,一行肯定显示不下四个,那你可能会想,那我宽度就少一点好了,比如设为20%,然后允许扩展,即flex-grow:1,那样不就可以把减去子元素宽度及外边距还剩下的空间再还给子元素了吗,试试看:

可以看到前面一切正常,但是最后一行因为只有一个元素,且设置了允许扩展,所以它被拉满整行了,这种效果显然不是我们要的。

其实我们可以使用内边距来做间距,设置一下子元素的box-sizing:border-box,让内边距包含在宽度内,这样就可以放心的把子元素的宽度设为25%了,当然这样的缺点是里面得再嵌套一个元素用来作为实际的内容容器。

圣杯布局

所谓圣杯布局如上所示,头尾高度固定,宽度占满,中间的内容部分分为三列,两侧宽度固定,高度占满,中间的内容部分随着浏览器宽度变化,其实就是我们上面讲过的【单列布局】的中间部分变成三列而已,实现完全没有啥特别的,以【单列布局】为基础,给content添加三个子元素,两侧定宽,并且不允许收缩,中间允许扩展即可:

垂直居中

不知道各位最开始用flex是为什么,反正笔者就是冲着垂直居中去的,用它实在是太简单了,之前还考虑是不是定高呀,用什么定位呀,用flex就是两步,一让父元素变成弹性盒子,二设置交叉轴的元素排布方式为居中就完事了:

如果还需要水平居中的话就再给容器元素设置主轴的排列方式为justify-content:center,现在连让文字居中我都是用flex,无情的抛弃了text-align和line-height。

高度自动对齐

有些时候同一列的元素为了美观我们希望他们的高度是一样的,如果内容固定不变当然可以直接写死高度,但如果可变的话就不能写死了:

这个场景使用flex完全不需要额外设置什么属性,只要给容器元素设置display:flex即可,因为flex容器有个属性align-items,用来设置flex子元素在交叉轴上如何对齐,默认值为stretch,即如果flex子元素未设置高度,那么将占满整个容器的高度,因为我们并没有给容器设置高度,所以容器的高度就是所有flex子元素里最大的高度。

小结

本文以标题党的名义总结了部分常见布局使用flex的实现,要灵活使用flex还是需要理解它的一些属性的意义,此外也需要知道flex的边界在哪,哪些是它不擅长的。

本文总结的难免会有不全,或者有更好的实现,欢迎讨论。

内推社群

我组建了一个氛围特别好的腾讯内推社群,如果你对加入腾讯感兴趣的话(后续有计划也可以),我们可以一起进行面试相关的答疑、聊聊面试的故事、并且在你准备好的时候随时帮你内推。下方加 winty 好友回复「面试」即可。

使用Flex实现常见布局的思路总结相关推荐

  1. 移动web开发--移动端常见布局+流式布局和flex布局+携程网首页案例

    浏览器私有前缀 为了兼容老版本 私有前缀 -moz- : fixfox 浏览器私有属性 -ms- : ie浏览器私有属性 -webkit- : safari.chrome私有属性 -o- : Oper ...

  2. 移动端有哪些常见布局方式?

    大家好,我是IT修真院深圳分院第九期的学员徐炜,一枚正直.纯洁.善良的前端程序员. 今天给大家分享一下,修真院官网css任务13,深度思考中的知识点--移动端有哪些常见布局方式? 1.背景介绍 随着智 ...

  3. Css学习总结(5)——CSS常见布局方式

    一.使用BFC隐藏属性 在对需要自适应的元素BFC化,可以实现两栏或三栏布局 使用BFC实现三栏布局时需要注意的是DOM的书写顺序问题.如果将aside2与article交换位置,那么aside2元素 ...

  4. 【CSS进阶】精灵图、字体图标、用户界面样式、常见布局技巧、初始化、CSS三角

    该系列文章是博主学习前端入门课程的笔记,同时也为了方便查阅,有任何问题都欢迎在评论区提出.本文主要介绍精灵图.字体图标.CSS三角.用户界面样式.vertical-align.常见布局技巧.初始化 思 ...

  5. 使用flex实现圣杯布局

    圣杯布局 首先需要了解圣杯布局的概念:圣杯布局是指左右宽度固定中间自适应的布局方式,是一个经典的布局 实现方式 在这里我使用的是flex方式来实现我们的圣杯布局. 布局思路:1,需要有三个盒子上中下排 ...

  6. 移动端web开发--开发选择、技术解决方案、常见布局

    1.移动端开发选择 1.1 移动端主流方案 1.单独制作移动端页面(主流) 2.响应式页面兼容移动端(其次) 1.2单独移动端页面(主流) 通畅在网址域名前加m(mobile)可以打开移动端.通过判断 ...

  7. HTML+CSS_第三部分(Flex弹性盒子布局、grid网格布局、移动端、移动端流式布局、移动端rem布局、响应式布局、Bootstrap框架)

    文章目录 (1)Flex弹性盒子布局 一: 父容器上的属性 1. display:flex 设置为弹性盒子(写在父容器上) 2.flex-direction值 设置子项的布局方向(写在父容器上) 3. ...

  8. Android中的常见布局

    文章目录 1 常见布局 2 创建布局的方式 1 常见布局 Android中的常见布局如下: 线性布局(LinearLayout): 相对布局(RelativeLayout): 帧布局(FrameLay ...

  9. html css图标怎么跟文字并排,CSS高级技巧:精灵图、字体图标、CSS三角做法、CSS用户界面样式、vertical-align属性应用、溢出文字省略号、常见布局技巧...

    CSS高级技巧目录 1.精灵图 使用原因:一个网页往往会有很多小的背景图片作为装饰,为了有效减少接收和发送请求的次数,提供页面加载速度,所以出现了精灵技术.核心原理就是将小图片整合到一张图里,这样浏览 ...

最新文章

  1. Android ScrollView 滑动指定的距离
  2. Linux定时备份mysql数据库
  3. 【Android 属性动画】属性动画 Property Animation 简介 ( 属性动画简介 | 属性动画特性 )
  4. 20. A *p=NULL,p 可以调用 A 类里面的函数嘛?
  5. SORT,DELETE ADJACEN DUPLICATES FROM保留有效数据
  6. STM32F103_USART_GPIO配置及相应的IO口设置
  7. Codeforces 1188A 构造
  8. 字符串乘一个数_【思维拓展】三位数乘两位数,构造最大积和最小积
  9. 95-190-448-源码-window-Trigger-CountTrigger
  10. 表格存储Tablestore权威指南(持续更新)
  11. c语言算法课件,《C语言常见算法》PPT课件.ppt
  12. 詹皇比肩乔丹!如何防住他?这是AI给出的回答
  13. Ubuntu下使用Monaco字体
  14. matlab的开方算法_matlab最大公约数 三种算法
  15. Webmax 2.0开启无限量下载
  16. 工业机器人pallet指令_工业机器人编程指令详解
  17. MySQL 去重SQL
  18. “蓝凤凰”开网店,卖起了这么多高颜值又神奇的生物
  19. 什么是集体户口,优势、劣势
  20. python3.8安装robotfrmework-ride安装及报错完美解决方法

热门文章

  1. Makefile中的奇葩字符
  2. 用课余时间取得计算机二级用英语怎么说,浙江省计算机二级有效期 领取证书时间...
  3. JavaScript和Java求字符串的字节长度
  4. JS获取扫码设备扫描到的值
  5. 7-6 进步排行榜 (10 分)
  6. 2019届高二(上)12月月考试题(文科)
  7. 爬虫学的好,牢饭吃的好 (入门篇)
  8. 震惊,中国历朝历代疆域变迁视频【高清】
  9. Hibernate方言
  10. SDWAN:直接互联网接入 (DIA)