移动端开发常用布局:前端弹性布局总结

各位已经入坑的前端小伙伴,前面咱们已经给大家分享了移动端开发时候流式布局的应用场景及注意事项,今天再次给大家分享一个布局叫弹性布局,接下来咱们从如下几个方面,全方位的给大家介绍弹性布局的使用.
一:什么是弹性布局?弹性布局(flex container),页面中任何一个元素只要设置了display:flex属性,那么当前盒子都称为弹性盒子.弹性盒子默认有两条轴: 默认水平显示的主轴 和 始终要垂直于主轴的侧轴(也叫交叉轴),在弹性盒子中所有的子元素都是沿着主轴方向显示 。

移动端开发常用布局:前端弹性布局总结

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

文章插图
 
②:以淘宝网页为例,当我们需要页面中多个子元素快速实现在父元素中以左右距离适中显示的时候,这个时候我们不需要设置任何的px值,只需要给元素设置
justify-content:space-around就可以实现.
移动端开发常用布局:前端弹性布局总结

文章插图
 
③:以携程为例,当页面中出现子元素按照其他比例分割父元素的时候,依然可以通过弹性盒子中的flex实现快速实现.如图:红色区域是按照 2:1:2 和 2:1:1:1的比例显示.
移动端开发常用布局:前端弹性布局总结

文章插图
 
如果咱们在写移动端页面(包括PC端页面)遇到以上几种情况的时候,弹性布局是最好的选择.
三:弹性布局的具体使用很多小伙伴都清楚弹性布局很好用,但是就是属性太多记不住而且还容易将属性对应的效果搞混,所以接下来我将给大家总结一下弹性布局中几个必须掌握的属性.
①:弹性布局第一步就是先给父元素设定为弹性盒子,既设置属性:display:flex.如代码所示:
移动端开发常用布局:前端弹性布局总结

文章插图
 
②:设置伸缩盒子的主轴方向,默认伸缩盒子中的主轴是水平显示,所以默认元素都是一行显示的.可以通过flex-direction属性调整主轴的方向,改变元素的显示方式
flex-direction: row的显示效果如下图所示:
移动端开发常用布局:前端弹性布局总结

文章插图
 
flex-direction:row-reverse的显示效果如下图所示:
移动端开发常用布局:前端弹性布局总结

文章插图
 
flex-direction:column的显示效果如下图所示:
移动端开发常用布局:前端弹性布局总结

文章插图
 
flex-direction:column-reverse的显示效果如下图所示:
移动端开发常用布局:前端弹性布局总结

文章插图
 
③:设置元素在主轴方向的对齐显示方式,通过justify-content属性实现
justify-content:flex-start的显示效果如下:
移动端开发常用布局:前端弹性布局总结

文章插图
 
justify-content:flex-end的显示效果如下:
移动端开发常用布局:前端弹性布局总结

文章插图
 
justify-content:space-between的显示效果如下:
移动端开发常用布局:前端弹性布局总结

文章插图
 
justify-content:space-around的显示效果如下:
移动端开发常用布局:前端弹性布局总结

文章插图
 
④:设置弹性盒子中元素在侧轴(交叉轴)方向的对齐方式通过align-items实现.
align-items: stretch 默认值的显示效果如下:
移动端开发常用布局:前端弹性布局总结

文章插图
 
align-items:flex-start显示效果如下:
移动端开发常用布局:前端弹性布局总结

文章插图
 
align-items:flex-end显示效果如下:
移动端开发常用布局:前端弹性布局总结

文章插图
 
align-items:center显示效果如下:
移动端开发常用布局:前端弹性布局总结

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


推荐阅读