不固定图片宽高瀑布流_图片横向等高瀑布流,每行占满,限制行数 的实现

本文介绍如何使用Flex布局实现图片的横向瀑布流效果,确保每行图片等高且占满行宽,通过合理配置flex-grow属性,动态计算图片的高度,保持图片比例的同时使布局更加美观。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

图片的横向瀑布流,其实简单地按顺序排列就可以了

但要实现每行中各图片都等高(各行不一定等高,但每行里面等高),且每行都占满,就需要用到flex的特性了

控制每行图片高度都一致,可能会影响图片的比例,所以不能简单暴力地设置高度,需要按比例来动态计算

另外,如要限制图片展示的行数,则只需判断好每行总高度与容器总高度的关系即可

这里就来实现一下这个小功能

8cd100d0d1f9d89191a279533cb2a38a.gif

因为都是假数据的关系,图片的宽高值是随机数,并非原图宽高值,仅作参考

看完上面那张大大的图,先想一下可以怎么实现..

要实现每行都能够占满,需要用到 flex-grow 这个属性

flex-grow基于flex-basis基准值来计算,而flex-basis则基于项目的width、min|max-width相关的值来计算,或者手动定义

使用flex-grow可以分配按比例分配主轴的剩余空间

如果有10张图片需要放置,第一行仅可以放置四张图片,剩余100px的空间,那么各图片的flex-grow可以直接配置成图片的宽度width值,即可很方便精准地分配好这剩余的空间

第二行可以放五张图片,剩余N px的空间... 按照这种计算方式来铺满每一行

获取最近更新

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值