弹性布局flex或者grid元素平分,实际会被内容撑大,问题剖析

flex item 平分

控制flex元素,有三个属性控制,flex-basis,flex-shrink,flex-grow 。如果期望这些元素能自动地扩展去填充满剩下的空间,那么我们需要去控制可用空间在这几个元素间如何分配,这就是元素上的那些 flex 属性要做的事。

flex-basis 控制元素空间的大小,默认是auto,自动分配小大以充分展示元素的内容;

flex-grow 值为整数,默认是0, 分配可用空间,如果其他元素也被允许延展,那么他们会各自占据可用空间的一部分;

flex-shrink 值为整数,默认是1 处理 flex 元素收缩的问题;

元素item平分,就需要在每个item设置flex:1,即自动伸缩,每个item伸缩等级都一样!!!

某个item设置了宽度,但是还是会被缩放!!!

 例如:

grid item 平分

grid-template-columns 基于网格列的维度,定义网格的尺寸大小 ;

grid-template-columns: repeat(4,1fr)

 元素item平分,每个item都是1fr!!!

 实际过程中,item并没有平分,而是根据item的内容伸缩了,这是为啥呢??

这时候我们来看下CSS中宽度的定义:

width:

注意点:min-width属性优先级高于width; 

min-witdh:

注意:当min-width大于width的值min-width会覆盖max-width和width; 

注意:min-width:auto用于弹性元素的默认最小宽度 

原因: 

通过上面弹性布局和元素width分析,当元素支持收缩时,min-width默认是auto,即元素内容的宽度,所以会导致item撑出平分的宽度!!如果设置宽度,由于是弹性布局,宽度也会被伸缩!!

解决: 

如果有宽度,希望宽度不被伸缩,需要把 flex-shrink:0,不允许伸缩!!

如果是平分,元素被撑大,只需要设置 min-width:0!!

同理:height也是一致的

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值