CSS flex-shrink 属性
实例
A, B, C 设置 flex-shrink:1, D , E 设置为 flex-shrink:2:
尝试一下 »
实例解析:
flex-shrink的默认值为1,如果没有显示定义该属性,将会自动按照默认值1在所有因子相加之后计算比率来进行空间收缩。
本例中A、B、C 显式定义了 flex-shrink 为 1,D、E 定义了 flex-shrink 为 2,所以计算出来总共将剩余空间分成了 7 份,其中 A、B、C 占 1 份,D、E 占 2 份,即1:1:1:2:2
我们可以看到父容器定义为 500px,子项被定义为 120px,子项相加之后即为 600 px,超出父容器 100px。那么超出的 100px 需要被 A、B、C、D、E 消化 通过收缩因子,所以加权综合可得 100*1+100*1+100*1+100*2+100*2=700px。
于是我们可以计算 A、B、C、D、E 将被移除的溢出量是多少:A 被移除溢出量:(100*1/700)*100,即约等于14px B 被移除溢出量:(100*1/700)*100,即约等于14px C 被移除溢出量:(100*1/700)*100,即约等于14px D 被移除溢出量:(100*2/700)*100,即约等于28px E 被移除溢出量:(100*2/700)*100,即约等于28px
最后A、B、C、D、E的实际宽度分别为:120-14=106px, 120-14=106px, 120-14=106px, 120-28=92px,120-28=92px,此外,这个宽度是包含边框的。
浏览器支持
表格中的数字表示支持该属性的第一个浏览器的版本号。
紧跟在 -webkit-, -ms- 或 -moz- 后的数字为支持该前缀属性的第一个版本。
属性 | |||||
---|---|---|---|---|---|
flex-shrink | 29.0 21.0 -webkit- |
11.0 10.0 -ms- |
28.0 18.0 -moz- |
9.0 6.1 -webkit- |
17.0 |
定义和用法
flex-shrink 属性指定了 flex 元素的收缩规则。flex 元素仅在默认宽度之和大于容器的时候才会发生收缩,其收缩的大小是依据 flex-shrink 的值。
注意:如果元素不是弹性盒对象的元素,则 flex-shrink 属性不起作用。
默认值: | 1 |
---|---|
继承: | 否 |
可动画化: | 是。请参阅 可动画化(animatable)。 尝试一下 |
版本: | CSS3 |
JavaScript 语法: | object.style.flexShrink="5" 尝试一下 |
CSS 语法
属性值
值 | 描述 |
---|---|
number | 一个数字,规定项目将相对于其他灵活的项目进行收缩的量。默认值是 1。 |
initial | 设置该属性为它的默认值。请参阅 initial。 |
inherit | 从父元素继承该属性。请参阅 inherit。 |
相关文章
CSS 参考手册:flex 属性
CSS 参考手册:flex-basis 属性
CSS 参考手册:flex-direction 属性
CSS 参考手册:flex-flow 属性
CSS 参考手册:flex-grow 属性
CSS 参考手册:flex-wrap 属性
1109531564
110***[email protected]
flex-shrink 将子元素宽度之和与父元素宽度的差值按照子元素 flex-shrink 的值分配给各个子元素,每个子元素原本宽度减去按比例分配的值,其剩余值为实际宽度。
以原有例子为模型,父元素命名为div0,1-5五个子元素分别命名为div1、div2、...、div5。
父元素需要设定:
所有子元素需要设定:
flex-basis:100px, 即不发生收缩时子元素原本的宽度
以上为先决条件。
子元素宽度之和与父元素宽度的差值:
这时通过设定子元素的flex-shrink属性来决定150px总缩减量如何分配给5个子元素。
按照之前的预设,div2 的实际宽度为其它子元素的 1/3。
设子元素的宽度分别为w1、w2、...、w5,div2的flex-shrink值与其它子元素flex-shrink的值之比为X,有如下方程组:
解方程组得
1109531564
110***[email protected]
栀夜。
774***[email protected]
参考地址
以mdn官方实例代码为例:
https://developer.mozilla.org/zh-CN/docs/Web/CSS/flex-shrink
教程中计算格式是有错误的:
1.每个元素宽度分别为 w1 w2 w3 w4 w5 ====> 每个均为120px
2.每个元素的shrink分别为 a, b, c, d, e ===> 1,1,1,2,2
3.超出宽度为 A = w1+w2+w3+w4+w5 - 父元素宽度 = 120+120+120+120+120 - 500 = 600px-500px = 100px
4.总压缩权重 W = a * w1 + b * w2 + c * w3 + d*w4+ e*w5 = 120*1 + 120*1+ 120*1 + 120*2 + 120*2 = 840
5.压缩率 S = a(flex-shrink)的值 * 宽度(w1) / 总压缩权重W; (这里以计算第一个为例子) 120 * 1/840 约等于 0.1428
6.最终结果宽度 = 本身宽度w1 - S * 超出宽度A ; 120 - 120 * 1/840 *100 = 120 - 14.28 = 105.75px
这是没有包含border在内的,因为例子中给出的有border,所以宽度计算时左右加上,每个元素为126px,计算结果如下
126 * 5 = 630
126 * 5 - 500 = 630 - 500 = 130
126 * 1 +126*1+126*1 +126*2+126*2 = 378 + 504 = 882
126 * 1 / 882 = 0.1428
126 - 126 * 1/882 *130 = 126 - 18.57= 107.43
最终结果应该为107.43
栀夜。
774***[email protected]
参考地址