flex 左右布局_移动端开发常用布局:前端弹性布局总结

各位已经入坑的前端小伙伴,前面咱们已经给大家分享了移动端开发时候流式布局的应用场景及注意事项,今天再次给大家分享一个布局叫弹性布局,接下来咱们从如下几个方面,全方位的给大家介绍弹性布局的使用.

一:什么是弹性布局?

弹性布局(flex container),页面中任何一个元素只要设置了display:flex属性,那么当前盒子都称为弹性盒子.弹性盒子默认有两条轴: 默认水平显示的主轴 和 始终要垂直于主轴的侧轴(也叫交叉轴),在弹性盒子中所有的子元素都是沿着主轴方向显示。

58c8ca2db323725e6e422a490f0b618e.png

二:什么情况下用弹性布局?

①: 以携程移动页面为例,在网页中当遇到需要将父元素按照奇数进行等分,比如携程中红色区域是将父元素3等分.如果用流式布局那么就需要设置33.33%.如果用弹性布局只需要给每一个子元素设置一个属性flex:1即可快速实现.

a8ebf2236e9be28b97890a2c89e608d0.png

②:以淘宝网页为例,当我们需要页面中多个子元素快速实现在父元素中以左右距离适中显示的时候,这个时候我们不需要设置任何的px值,只需要给元素设置justify-content:space-around就可以实现.

48bcfa17a79d07150e0871818945affc.png

③:以携程为例,当页面中出现子元素按照其他比例分割父元素的时候,依然可以通过弹性盒子中的flex实现快速实现.如图:红色区域是按照 2:1:2 和 2:1:1:1的比例显示.

d356df0f8b65c7e0aba4f36b8fca7ded.png

如果咱们在写移动端页面(包括PC端页面)遇到以上几种情况的时候,弹性布局是最好的选择.

三:弹性布局的具体使用

很多小伙伴都清楚弹性布局很好用,但是就是属性太多记不住而且还容易将属性对应的效果搞混,所以接下来我将给大家总结一下弹性布局中几个必须掌握的属性.

①:弹性布局第一步就是先给父元素设定为弹性盒子,既设置属性:display:flex.如代码所示:

74ec4bcc67010ca6a99bf82d8123cd91.png

②:设置伸缩盒子的主轴方向,默认伸缩盒子中的主轴是水平显示,所以默认元素都是一行显示的.可以通过flex-direction属性调整主轴的方向,改变元素的显示方式

flex-direction: row的显示效果如下图所示:

126d514a11b50d92d17639d8a0f77f26.png

flex-direction:row-reverse的显示效果如下图所示:

66fdb880e26ea91356c61a7ac8bc07e4.png

flex-direction:column的显示效果如下图所示:

16dc31be57cde6e238c6cb36934d0fd8.png

flex-direction:column-reverse的显示效果如下图所示:

f19be24dbf987560ea22854a06d5d364.png

③:设置元素在主轴方向的对齐显示方式,通过justify-content属性实现

justify-content:flex-start的显示效果如下:

b505ca72e7416e7b545f990b7f30e993.png

justify-content:flex-end的显示效果如下:

acf5a4e1653f3e7df193e0d9adfba018.png

justify-content:space-between的显示效果如下:

9bc96c88b231afe05bb83e92e0c72ecf.png

justify-content:space-around的显示效果如下:

9ab76db8394d98a4897ad75536aa62e5.png

④:设置弹性盒子中元素在侧轴(交叉轴)方向的对齐方式通过align-items实现.

align-items: stretch 默认值的显示效果如下:

45b5910c233733cc505ceed3a14f3a61.png

align-items:flex-start显示效果如下:

89d2cafef834dd7f4d547c1bb24d4407.png

align-items:flex-end显示效果如下:

992952be7e7c695b8ef1e4f84f85d071.png

align-items:center显示效果如下:

4cd82661f9ba229bc260075c545b183b.png

⑤:在伸缩盒子中,默认所有的子元素超出父容器宽度后都不换行显示,如果希望让超出父元素后换行显示,可以通过flex-wrap属性实现

flex-wrap:nowrap 默认效果如下:

6abf0b10d3628970dd7b5e87f8893560.png

flex-wrap:wrap 显示效果如下:

850f129bed2997869b2acb53fd7d138b.png

⑥:在伸缩和中元素换行后设置多行对齐方式,通过align-content属性实现

align-content:stretch默认值显示效果:

3795e8a9f61e4951114dd8cc2daf9531.png

align-content:flex-start 显示效果如下:

f6be866ad2f87f6cf53573d30e69fd58.png

align-content:flex-end 显示效果如下:

942af43d53def84b157fc8203450c893.png

align-content:center 显示效果如下:

eb344e67ef41d4926ff835360e2de9c8.png

align-content: space-between 显示效果如下

725f408e7e8a89690fb731945fa3ae78.png

align-content: space-around显示效果如下:

26a491a9955584c13d41e7a826f95cf1.png

以上属性都是给弹性盒子设置的属性,各位小伙伴要注意.如下代码所示:

3f1b05c11b0747b20d014f1c1574fcb9.png

⑦:如果希望弹性盒子中子元素按照任何一个比例显示,可以给子元素设置flex属性,如下图所示:

Flex: 1.代表子元素占父元素空间宽度的一份.

75b727de3f4980d1fc4fb919eca80479.png

Felx:2代表子元素占父元素空间宽度的2份,依次类推

0da3eda1ab42b2bbaee330674f36e282.png

三: 弹性布局优缺点分析

弹性布局在网页中实现快速分配比例,盒子快速对齐优势很大,因为通过简单的几个属性就可以实现,进而减少我们设置具体值.但是弹性布局中的属性对于浏览器版本要求比较严格,如果浏览器版本太低那么弹性布局中的属性是无法正常使用的.如下图所示:

2039e9f1f6da458f5bd8ec5837f7aab6.png

写在最后的几句话,送给大家.学习任何知识都不是为了去解决某个特定问题的.我们学的知识可以当成是我们工具包中的一个新工具.在恰当的时候使用恰当的工具解决问题就可以了.针对弹性布局中还有其他属性,由于我们在写页面的过程中不是经常用到,所以今天主要分享给大家弹性布局中我们必须会的. 好的这个章节就讲到这里。

黑马最新活动:

黑马程序员2020年java中级程序员学习路线图、全部资源免费大放送,点击下方:“了解更多”的链接就可进入页面领取哦。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Flex布局是一种用来为盒状模型提供最大灵活性的布局方式。它是移动端开发中非常重要的布局方式,被广泛应用于80%以上的移动端开发中。与rem媒体查询结合使用,可以说是移动端开发的主流布局方式。 Flex布局的原理是通过给父容器添加flex属性来控制子项目的位置和排列方式。当我们将父容器设置为flex布局后,子元素的float、clear和vertical-align属性将失效。Flex容器中的子元素自动成为容器成员,称为Flex项目。 要实现Flex布局,只需要为父容器添加display:flex;属性即可。通过设置不同的flex属性值,可以实现不同的布局效果。例如,设置flex-direction: row;可以使子项目横向排列,而设置flex-direction: column;则可以使子项目纵向排列。 总之,Flex布局是一种弹性的、灵活的布局方式,适用于移动端开发,并可以与rem媒体查询结合使用,是移动端开发中的主流布局方式。它通过给父容器添加flex属性来控制子项目的位置和排列方式,为开发者提供了更大的布局自由度。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [移动端flex布局](https://blog.csdn.net/yexiangCSDN/article/details/116591641)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值