css实现瀑布流布局

瀑布流布局也可以通过纯CSS来实现,使用CSS的column属性可以实现多列布局。下面是一个使用纯CSS实现瀑布流布局的示例:

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>瀑布流布局</title>
<style>
    .waterfall {
        column-count: 4;
        column-gap: 10px;
    }

    .item {
        break-inside: avoid-column;
        margin-bottom: 10px;
    }

    .item img {
        width: 100%;
        display: block;
    }
</style>
</head>
<body>
<div class="waterfall">
    <div class="item"><img src="https://via.placeholder.com/150" alt=""></div>
    <div class="item"><img src="https://via.placeholder.com/200" alt=""></div>
    <div class="item"><img src="https://via.placeholder.com/250" alt=""></div>
    <div class="item"><img src="https://via.placeholder.com/300" alt=""></div>
    <div class="item"><img src="https://via.placeholder.com/350" alt=""></div>
    <div class="item"><img src="https://via.placeholder.com/400" alt=""></div>
    <div class="item"><img src="https://via.placeholder.com/450" alt=""></div>
    <div class="item"><img src="https://via.placeholder.com/500" alt=""></div>
</div>
</body>
</html>

在这个示例中,我们使用CSS的column-count属性将.waterfall容器分为4列,使用column-gap属性设置列与列之间的间距。然后通过break-inside: avoid-column属性确保.item元素不会被分割到两列之间。最后,设置.item img元素的宽度为100%以确保图片占满整个列,并设置display: block以消除图片之间的空隙。

通过这种方式,我们可以实现一个简单的瀑布流布局,不需要额外的JavaScript代码。你可以根据实际需求调整列数、间距和元素样式等来实现不同的效果。

相关推荐
白中白121384 分钟前
Vue系列-3
前端·javascript·vue.js
沛沛老爹4 分钟前
Vue3+TS实战:基于策略模式的前端动态脱敏UI组件设计与实现
前端·ui·vue3·数据安全·策略模式·动态渲染·前端脱敏
陈随易11 分钟前
CDN的妙用,隐藏接口IP,防DDOS攻击
前端·后端·程序员
明月_清风12 分钟前
单点登录(SSO)在前端世界的落地形态
前端·安全
九丝城主16 分钟前
1V1音视频对话2--Web 双浏览器完整通话测试(强制 relay)
前端·音视频
C澒16 分钟前
以微前端为核心:SLDSMS 前端架构的演进之路与实践沉淀
前端·架构·系统架构·教育电商·交通物流
明月_清风17 分钟前
OAuth2 与第三方登录的三个阶段(2010–至今)
前端·安全
We་ct18 分钟前
LeetCode 138. 随机链表的复制:两种最优解法详解
前端·算法·leetcode·链表·typescript
dcmfxvr19 分钟前
【无标题】
java·linux·前端
SoaringHeart37 分钟前
Flutter 顶部滚动行为限制实现:NoTopOverScrollPhysics
前端·flutter