①flex设置1和auto有什么区别,
②设置成1,basis是0%,0%怎么理解,
③设置成auto按照解释basis值应该为auto这又是什么意思,
④而且设置成auo,用autoprefix加上前缀-webkit-box对应值还是1,这什么鬼?
①flex设置1和auto有什么区别,
②设置成1,basis是0%,0%怎么理解,
③设置成auto按照解释basis值应该为auto这又是什么意思,
④而且设置成auo,用autoprefix加上前缀-webkit-box对应值还是1,这什么鬼?
.x{
flex:1 1 auto;
}
autoprefix之后
.x{
-webkit-box-flex:1;
-webkit-flex:1 1 auto;
-ms-flex:1 1 auto;
flex:1 1 auto;
}
所以旧版语法是不支持auto的是吗,那么如果希望初始以子元素的宽度布局,根据剩余或者溢出空间重新计算要怎么做呢?@HaoyCn
8 回答4.6k 阅读✓ 已解决
6 回答3.3k 阅读✓ 已解决
6 回答2.2k 阅读
5 回答6.3k 阅读✓ 已解决
5 回答1.2k 阅读✓ 已解决
3 回答2.4k 阅读✓ 已解决
3 回答1.3k 阅读✓ 已解决
这是一句和回答无关的话:我是来谢赞的 :)
以下个人测试,如有纰漏错误恳请指正:
首先明确一点是,
flex
是flex-grow
、flex-shrink
、flex-basis
的缩写。故其取值可以考虑以下情况:flex
的默认值是以上三个属性值的组合。假设以上三个属性同样取默认值,则flex
的默认值是 0 1 auto。同理,如下是等同的:当
flex
取值为none
,则计算值为 0 0 auto,如下是等同的:当
flex
取值为auto
,则计算值为 1 1 auto,如下是等同的:当
flex
取值为一个非负数字,则该数字为flex-grow
值,flex-shrink
取 1,flex-basis
取 0%,如下是等同的:当
flex
取值为一个长度或百分比,则视为flex-basis
值,flex-grow
取 1,flex-shrink
取 1,有如下等同情况(注意 0% 是一个百分比而不是一个非负数字):当
flex
取值为两个非负数字,则分别视为flex-grow
和flex-shrink
的值,flex-basis
取 0%,如下是等同的:当
flex
取值为一个非负数字和一个长度或百分比,则分别视为flex-grow
和flex-basis
的值,flex-shrink
取 1,如下是等同的:flex-basis
规定的是子元素的基准值。所以是否溢出的计算与此属性息息相关。flex-basis
规定的范围取决于box-sizing
。这里主要讨论以下flex-basis
的取值情况:auto
:首先检索该子元素的主尺寸,如果主尺寸不为auto
,则使用值采取主尺寸之值;如果也是auto
,则使用值为content
。content
:指根据该子元素的内容自动布局。有的用户代理没有实现取content
值,等效的替代方案是flex-basis
和主尺寸都取auto
。百分比:根据其包含块(即伸缩父容器)的主尺寸计算。如果包含块的主尺寸未定义(即父容器的主尺寸取决于子元素),则计算结果和设为
auto
一样。举一个不同的值之间的区别:
主轴上父容器总尺寸为 600px
子元素的总基准值是:0% + auto + 200px = 300px,其中
故剩余空间为 600px - 300px = 300px
伸缩放大系数之和为: 2 + 2 + 1 = 5
剩余空间分配如下:
各项目最终宽度为:
当 item-1 基准值取 0% 的时候,是把该项目视为零尺寸的,故即便声明其尺寸为 140px,也并没有什么用,形同虚设
而 item-2 基准值取
auto
的时候,根据规则基准值使用值是主尺寸值即 100px,故这 100px 不会纳入剩余空间更多资料可以参考:
http://www.w3.org/html/ig/zh/css-flex-1/