flex-grow、flex-shrink、flex-basis详解
来源:互联网 发布:淘宝的保证金怎么退 编辑:程序博客网 时间:2024/06/08 08:31
作者:九彩拼盘链接:http://www.jianshu.com/p/0642dfe0e571來源:简书著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。flex-grow、flex-shrink、flex-basis这三个属性的作用是:在flex布局中,父元素在不同宽度下,子元素是如何分配父元素的空间的。
其中,这三个属性都是在子元素上设置的。
注:下面讲的父元素,指以flex布局的元素(display:flex)。flex-basis
该属性来设置该元素的宽度。当然,
width
也可以用来设置元素宽度。如果元素上同时设置了width
和flex-basis
,那么flex-basis
会覆盖width
的值。flex-grow
该属性来设置,当父元素的宽度大于所有子元素的宽度的和时(即父元素会有剩余空间),子元素如何分配父元素的剩余空间。
flex-grow
的默认值为0,意思是该元素不索取父元素的剩余空间,如果值大于0,表示索取。值越大,索取的越厉害。
举个例子:
父元素宽400px,有两子元素:A和B。A宽为100px,B宽为200px。
则空余空间为 400-(100+200)= 100px。
如果A,B都不索取剩余空间,则有100px的空余空间。
如果A索取剩余空间:设置flex-grow为1,B不索取。则最终A的大小为 自身宽度(100px)+ 剩余空间的宽度(100px)= 200px
如果A,B都设索取剩余空间,A设置flex-grow为1,B设置flex-grow为2。则最终A的大小为 自身宽度(100px)+ A获得的剩余空间的宽度(100px * (1/(1+2))),最终B的大小为 自身宽度(200px)+ B获得的剩余空间的宽度(100px * (2/(1+2)))flex-shrink
该属性来设置,当父元素的宽度小于所有子元素的宽度的和时(即子元素会超出父元素),子元素如何缩小自己的宽度的。
flex-shrink
的默认值为1,当父元素的宽度小于所有子元素的宽度的和时,子元素的宽度会减小。值越大,减小的越厉害。如果值为0,表示不减小。
举个例子:
父元素宽400px,有两子元素:A和B。A宽为200px,B宽为300px。
则A,B总共超出父元素的宽度为(200+300)- 400 = 100px。
如果A,B都不减小宽度,即都设置flex-shrink为0,则会有100px的宽度超出父元素。
如果A不减小宽度:设置flex-shrink为0,B减小。则最终B的大小为 自身宽度(300px)- 总共超出父元素的宽度(100px)= 200px
如果A,B都减小宽度,A设置flex-shirk为3,B设置flex-shirk为2。则最终A的大小为 自身宽度(200px)- A减小的宽度(100px*
(200px*
3/(200*
3 + 300*
2))) = 150px,最终B的大小为 自身宽度(300px)- B减小的宽度(100px*
(300px*
2/(200*
3 + 300*
2))) = 250px详细说明见深入理解 flex-grow & flex-shrink & flex-basis。
- flex-grow、flex-shrink、flex-basis详解
- flex-grow、flex-shrink、flex-basis详解
- flex-grow、flex-shrink、flex-basis详解、flex:1;详解
- 戏说flex-grow、flex-shrink、flex-basis
- 深入理解 flex-grow & flex-shrink & flex-basis
- css3 flex属性flex-grow、flex-shrink、flex-basis学习笔记
- css3 flex属性flex-grow、flex-shrink、flex-basis学习笔记
- Flex弹性布局之flex-basis、flex-grow、flex-shrink分析
- Flex入门基础——项目item的属性(order、flex-grow、flex-shrink、flex-basis、flex、align-self)
- HTML5基础加强css样式篇(伸缩容器子元素属性:order,flex-grow,flex-shrink,flex-basis,flex,align-self)(五十四)
- flex-grow
- flex-shrink
- flex-basis
- flex 中的flex-basis
- Flex布局中的Flex-Grow无效问题
- FLEX
- flex
- flex
- Python3之实现单例模式de几种方式
- Js如何调用本地应用程序
- Piontcut is not well-formed
- 史上最简单的SpringCloud教程 | 第六篇: 分布式配置中心(Spring Cloud Config)
- JSON.parse(),JSON.stringify(),jQuery.parseJSON()的用法
- flex-grow、flex-shrink、flex-basis详解
- NKOJ 4151 (TJOI 2016&HEOI 2016)字符串(后缀数组+倍增+主席树)
- 度盘会员破解
- Java JDK 环境变量的配置
- spring boot注解
- 使用cmd命令创建thinkphp5中的资源控制器
- 汉诺塔用递归算法
- win10下安装TensorFlow1.4.0-GPU
- 67 个拯救前端开发者的工具、库和资源