flex-grow、flex-shrink、flex-basis详解
来源:互联网 发布:java 时间转换 毫秒 编辑:程序博客网 时间:2024/06/05 05:37
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 *
(3 / (3 + 2))) = 150px,最终B的大小为 自身宽度(300px)- B减小的宽度(100px*
(2 / (3 + 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
- 一个单词统计的实例,怎样通过MapReduce完成排序?
- Docs » Logs » Diagnosing problems using Logs
- MFC 控件添加ToolTip
- 开源许可协议GPL、APL、BSD、LGPL、MIT
- string的find操作
- flex-grow、flex-shrink、flex-basis详解
- hibernate概述及基础知识
- cnanot find xxxx.so 异常的解决方案
- 如何针对产品销售设计一套有效的奖励和惩罚销售措施?
- 第四十六篇: JAVA加密解密之消息摘要算法(MessageDigest)
- 分布式事务与一致性算法Paxos & raft & zab
- ANDROID内存优化
- 《并发编程》--13.CountDownLatch和CyclicBarrier
- 宏基因组文章目录(9月1日更新)