什么是瀑布流?

看一张图,以下图片来源于花瓣网截图:

如上图所示,瀑布流就是让内容按列显示,自动填充空白。

使用 column 实现瀑布流

源码:

<div class="masonry">
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
</div>
<style>
:root{
--item-bg-1: #ff4757;
--item-bg-2: #cea442;
--item-bg-3: #18005f;
--counter-bg: #dedede;
} .masonry {
column-count: 1;
column-gap: 20px;
/* 重置计数器 */
counter-reset: item-counter; }
/* 使用媒体查询处理不同视口宽度显示不同列数 */
@media screen and (min-width: 400px) {
.masonry {
column-count: 2;
}
} @media screen and (min-width: 600px) {
.masonry {
column-count: 3;
}
} @media screen and (min-width: 800px) {
.masonry {
column-count: 4;
}
} @media screen and (min-width: 1200px) {
.masonry {
column-count: 5;
}
} .item {
box-sizing: border-box;
break-inside: avoid;
margin: 0 0 20px;
/* css 计数器 */
counter-increment: item-counter;
position: relative;
}
/* 显示计数器 */
.item:before {
position: absolute;
top: 0;
left: 0;
padding: 8px 0;
min-width: 2em;
text-align: center;
background-color: var(--counter-bg);
content: counter(item-counter);
}
/* 给 item 设置不同的高度和背景色 */
.item:nth-child(7n+1) {
height: 151px;
background-color: var(--item-bg-1);
}
.item:nth-child(7n+2) {
height: 187px;
background-color: var(--item-bg-2);
}
.item:nth-child(7n+3) {
height: 289px;
background-color: var(--item-bg-3);
}
.item:nth-child(7n+4) {
height: 123px;
background-color: var(--item-bg-1);
}
.item:nth-child(7n+5) {
height: 234px;
background-color: var(--item-bg-2);
}
.item:nth-child(7n+6) {
height: 188px;
background-color: var(--item-bg-3);
}
.item:nth-child(7n+7) {
height: 149px;
background-color: var(--item-bg-1);
}
</style>

效果:

视口宽度大于 1200px 时,显示 5 列:

视口宽度在 600px-800px 之间时,显示 3 列:

column 相关属性

column-count

column-count 声明显示多少列。默认值为 auto,由浏览器自己决定。

column-fill

column-fill 控制元素内容分成列时的平衡方式。有效值:auto(按顺序填充列)、balance(仅最后一页内容平均分配到各列)、balance-all(全部分页内容平均分配到各列)。

column-gap

column-gap 设置列间隔。默认值 normal 表示列间距占用 1em 宽度。

column-rule

column-rule 简写属性,包含 column-rule-width、column-rule-style 和 column-rule-color 。

column-rule-width 设置线条宽度。

column-rule-style 与 border-style 一样,支持值:none 、 hidden 、 dotted 、 dashed 、 solid 、 double 、 groove 、 ridge 、 inset 、 outset。

column-rule-color 设置线条颜色。

column-span

column-span 设置子元素是否跨列显示。有效值:none(不跨列)、all(跨列)。

column-width

column-width 设置列的宽度。浏览器会自动调整宽度大小,如果设置的宽度连两列都放不下,会自动变为一列显示(如图三)。

columns

columns 简写属性,可组合设置 column-width 和 column-count 属性。

grid 实现瀑布流

源码:

<div class="masonry">
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
<div class="item">
</div>
</div>
<style>
:root{
--item-bg-1: #ff4757;
--item-bg-2: #cea442;
--item-bg-3: #18005f;
--counter-bg: #dedede;
} .masonry {
display: grid;
grid-gap: 20px;
grid-auto-flow: dense row;
grid-template-columns: repeat(9, 1fr);
grid-auto-rows: minmax(50px, auto);
/* 重置计数器 */
counter-reset: item-counter;
} .item {
box-sizing: border-box;
/* css 计数器 */
counter-increment: item-counter;
position: relative;
}
/* 显示计数器 */
.item:before {
position: absolute;
top: 0;
left: 0;
padding: 8px 0;
min-width: 2em;
text-align: center;
background-color: var(--counter-bg);
content: counter(item-counter);
}
/* 给 item 设置不同的高度和背景色 */
.item:nth-child(7n+1) {
grid-row: 1 / 4;
background-color: var(--item-bg-1);
}
.item:nth-child(7n+2) {
grid-row: 1 / 3;
background-color: var(--item-bg-2);
}
.item:nth-child(7n+3) {
grid-row: 1 / 4;
background-color: var(--item-bg-3);
}
.item:nth-child(7n+4) {
grid-row: 4 / 7;
background-color: var(--item-bg-1);
}
.item:nth-child(7n+5) {
grid-row: 3 / 9;
background-color: var(--item-bg-2);
}
.item:nth-child(7n+6) {
grid-row: 4 / 8;
background-color: var(--item-bg-3);
}
.item:nth-child(7n+7) {
grid-row: 7 / 11;
background-color: var(--item-bg-1);
}
</style>

效果:

写在最后

在多列布局方面 column 属性相比于 flex 和 grid 而言,显得更有优势。

虽说 grid 也能做出瀑布流效果,不过需要指定每个网格单元的占用大小。

column 虽然不用控制每个子项的大小,但它的子元素排列顺序是从上到下排列,并不是从左往右,这种情况如果数据存在分页加载时候,就会出现内容重新排列导致内容闪动。

在瀑布流布局这个需求场景下,CSS 多多少少还是有点弱鸡~~必要时候还是只有祭出 JS 。

其他相关资料:

break-* 控制多列布局如何中断换列: https://developer.mozilla.org/zh-CN/docs/Web/CSS/break-inside

Web前端入门第 48 问:纯 CSS 使用 column 属性实现瀑布流布局的更多相关文章

  1. web前端入坑第五篇:秒懂Vuejs、Angular、React原理和前端发展历史

    秒懂Vuejs.Angular.React原理和前端发展历史 2017-04-07 小北哥哥 前端你别闹 今天来说说 "前端发展历史和框架" 「前端程序发展的历史」 「 不学自知, ...

  2. Android零基础入门第48节:可折叠列表ExpandableListView

    原文:Android零基础入门第48节:可折叠列表ExpandableListView 上一期学习了AutoCompleteTextView和MultiAutoCompleteTextView,你已经 ...

  3. web前端入坑第二篇:web前端到底怎么学?干货资料! 【转】

    http://blog.csdn.net/xllily_11/article/details/52145172 版权声明:本文为博主[小北]原创文章,如要转载请评论回复.个人前端公众号:前端你别闹,J ...

  4. 给 Web 前端开发人员推荐20款 CSS 编辑器

    CSS 和 HTML,JavaScript 是网页的基础,作为前端开发人员,对这三者都要很熟悉.特别是未来流行全栈开发的时代,每项技术都是你知识结构中必要的一个节点. 在开发中,选择好工具是非常重要的 ...

  5. web前端知识大纲:系列二 css篇

    web前端庞大而复杂的知识体系的组成:html.css和 javascript 二.css 1.CSS选择器 CSS选择器即通过某种规则来匹配相应的标签,并为其设置CSS样式,常用的有类选择器.标签选 ...

  6. Web前端开发规范【HTML/JavaScript/CSS】

    前言 这是一份旨在增强团队的开发协作,提高代码质量和打造开发基石的编码风格规范,其中包含了 HTML, JavaScript 和 CSS/SCSS 这几个部分.我们知道,当一个团队开始指定并实行编码规 ...

  7. web前端基础知识-(二)CSS基本操作

    1. 概述 css是英文Cascading Style Sheets的缩写,称为层叠样式表,用于对页面进行美化. 存在方式有三种:元素内联.页面嵌入和外部引入,比较三种方式的优缺点. 语法:style ...

  8. Web前端面试指导(十九):CSS样式-如何清除元素浮动?

    题目点评 本题属于比较常问的题目,也是在网页设计中经常遇到的问题,面试官希望通过这样的面试题来了解你对网页设计的基本功底,如果这样的题目答不出来,必会让面试官大失所望,面试成功的概率是非常小的. 答题 ...

  9. 【WEB前端开发最佳实践系列】CSS篇

    一.有效组织CSS代码 规划组织CSS代码:组织CSS代码文件,所有的CSS都可以分为2类,通用类和业务类.代码的组织应该把通用类和业务类的代码放在不同的目录中. 模块内部的另一样式规则:样式声明的顺 ...

  10. Web前端面试指导(十五):CSS样式-display有哪些作用?

    题目点评 其实就是要你说清楚该属性有哪些值,每个值都有什么作用,这个题目可以答得很简单,但要答全也并非是一件容易的事情. 元素默认的display值的情况如下(这个一般很少人注意这一点) block( ...

随机推荐

  1. 支付宝云Serveless+豆包AI实现AI日语学习APP

    1. 引言 最近学日语,发现动词.形容词的变形规则又多又复杂,在不同语境里变化也不一样,句子结构和语法也很麻烦.为了提高学习效率,决定开发基于AI的日语学习APP,借助 AI 进行辅助学习,目前已经完 ...

  2. vue打印浏览器页面功能的两种实现方法

    目录 方法一:通过npm 安装插件 方法二:手动下载插件到本地 总结 推荐使用方法二 方法一:通过npm 安装插件 1,安装 npm install vue-print-nb --save 2,引入 ...

  3. 2024年最新iOS 17屏蔽系统更新方法,iPhone、iPad通用!

    到Safari浏览器打开,描述文件会自动安装进手机里. 这时候我们在设置里,找到设备管理,点击刚刚下载好的描述文件,进行安装.要注意看,有苹果的签名,才说明是官方出品,千万要注意哦!安装完成后,重启手 ...

  4. 重生之数据结构与算法----数组&链表

    简介 数据结构的本质,只有两种结构,数组与链表.其它的都是它的衍生与组合 算法的本质就是穷举. 数组 数组可以分为两大类,静态数组与动态数组. 静态数组的本质是一段连续的内存,因为是连续的,所以我们可 ...

  5. 写于vue3.0发布前夕的helloworld之四

    OK.接上回到render: with(this){return _c('div',{attrs:{"id":"app"}},[_v(_s(msg))])} 接 ...

  6. msvcp110.dll丢失修复 按我的方法来,保证修复!

    方法很简单,msvcp110.dll丢失,安装Microsoft Visual C++ 2012 Redistributable Package就可以,我把修复程序的链接放下面.链接地址: 链接:ht ...

  7. 入门Dify平台:如何根据需求选择与创建最合适的应用

    今天我们将继续深入讲解Dify,重点介绍如何创建应用.具体来说,我们将探讨如何根据不同的需求来决定选择什么类型的应用最为合适,帮助大家更好地理解在Dify平台上构建应用的最佳实践. 创建空白应用 首先 ...

  8. JdbcTemplate 自定义返回的结果集字段和实体类映射

    废话不多:抄袭代码 package com.webank.wedatasphere.qualitis.handler; import com.webank.wedatasphere.qualitis. ...

  9. 数据质量框架QUalitis浅尝使用

    数据质量管理平台(微众银行)Qualitis+Linkis (一)Qualitis是一个数据质量管理系统,用于监控数据质量. 其功能包括: 数据质量模型定义 数据质量结果可视化 可监控 数据质量管理服 ...

  10. 面试官:工作中优化MySQL的手段有哪些?

    MySQL 是面试中必问的模块,而 MySQL 中的优化内容又是常见的面试题,所以本文来看"工作中优化MySQL的手段有哪些?". 工作中常见的 MySQL 优化手段分为以下五大类 ...