记一次flex-shrink的问题

mobile的轮播图的错误显示问题,大概也就是320宽的屏幕,4张图,每张图显示只有80px
1.flex-shrink的默认值是1,所以算法也就是
originImageWidth(我的测试图为750) - width * flex-shrink/weight * totalWidth
2.以一张750图为例,在宽度是320的屏幕里,可套公式:
750 - 750*1/3000 * 2680 = 80,此时收缩因子为0.25,此时收缩因子为0.25,2680是四张图3000的宽度-屏宽320也,
就得出了正确结论,这个就是导致轮播图宽度只有80的结果
解决办法也很简单:思路和伪代码
<div class='wrapper'>
img * 4
</div>
less:
.wrapper{
width:100%;flex-shrink:0
&img{
width:100%
}
}
也就是先将div宽度先适应成屏宽,然后使其内部img适应当前div宽度,因为flex-shrink:0导致收缩因子为0,所以可以使用两个百分比控制宽高
图一对应flex-shrink默认为1
图二对应flex-shrink:0
图三对应未使用百分比情况,导致图片回归本身大小

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值