你不知道的CSS超强布局🤡——砌体布局,一行代码解决布局问题!

先叠个保护壳:作者才大二能力有限,各位大佬如果发现有不认同的地方,请大家轻点喷🙏

事情起因是这样的,大家在刷抖音,小红书等短视频平台、发现他们的布局是这样的瀑布流布局 知道是瀑布流后,怎么做呢?我们第一反应是flex,grid?是的这是大部分人的固态思维

我认为这极为麻烦,因为你甚至还需要用到大量的@meida,javascript来解决细节问题,代码极其冗杂。

全文的大前提:不考虑图片顺序。

但是砌体布局使用columns后仅仅一行代码就能完成上述的功能!!🤩,这你还不学起来?

我查阅了许多博客,发现大多数对于使用column仅仅也就是介绍了多列布局,但是!!!!它的作用不仅仅如此,至少在这种不考虑顺序的瀑布流布局下,我认为它是最强的。

砌体布局原理就是使用column将元素分为不同的列,然后元素会自动填充空白的部分。但这还不是最特别的,列不是仅仅基于数量,而是可以根据每件物品的尺寸,自动进行响应式!!amazing!

如果本文对你有帮助,不妨评论,点赞和收藏,这是对我更新文章最大的动力,我会持续更新劲爆的内容。如果可能的话,在年度作者活动中为孩子投上一票。

Grid

这里代码我准备了很多图片,他们拥有不同的比例和尺寸

我们先来看grid布局怎么做的。

css 复制代码
.layout-container {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
    }

缺点很明显,这种方法会将图片强制分为三列,但是中间会出现许多剩余部分,这极为丑陋,你需要通过其他方法来解决这些,这里就不深入说了,毕竟这不是重点。

Flex

ok,让我们来看看flex怎么做

css 复制代码
img {
      width: 100%;
      margin-bottom: 1em;
    }

    .layout-container {
      display: flex;
      /* 允许换行,但是图像扭曲了 */
      flex-wrap: wrap;
    }

我们可以发现图片占满了整个屏幕

修复方法

css 复制代码
img {
      width: 100%;
      margin-bottom: 1em;
      /* 只需要添加对象修复覆盖即可 */
      max-width: 300px;
      object-fit: cover;
    }

    .layout-container {
      display: flex;
      flex-wrap: wrap;
    }

修复后。间隔消失,并且整齐排列,但是发现很多图片缺了一块(比如第一行第三列),这不是我们要的效果, 我们要的是保留图片的原比例,

砌体布局:container-visibility!

重头戏来了,砌体布局!

我们只需要要一行代码便能完美解决这个问题

column-count

css 复制代码
    img {
      width: 100%;
      margin-bottom: 1em;
    }

    .layout-container {
      column-count: 3;
    }

是的你没看错,我们仅仅用了这一行代码,便解决了这个问题。 column-count: 3:把图片分为三列,在保持图片比例的情况下,又能填充空白部分。

但是细节的大佬就发现了,它不是响应式的,那不炸了吗。

我们用@media就能解决了,你以为我会用吗?😡那岂不是不又要写一堆@media来适配,这违背了我写这篇文章的目的,告诉你,不需要!!!😏一行代码搞定!

我们先看@media怎么实现🚀

css 复制代码
    @media screen and (max-width: 600px) {
      .layout-container {
        column-count: 2;
      }
    }

可以发现的确解决了响应式的问题。

Now😍!睁开你们的眼睛👀,一行代码写完。

css 复制代码
.layout-container {
      columns: 300px;
    }

columns: 300px 将列设置为300像素,系统按300像素划分列,自动进行响应式布局,如果下一张图片给它剩的位置不够,那么就会自动到下一行去,并且剩余的空间将会自动被填满。

Perfect!😄这种布局方式简直太爽了。🚀🚀

有缺点吗,当然有

因为它是从上往下排序,如果我们需要一些动态加载图片的业务,那么新加入的图片将不会加入页面的最低端,不符合我们的业务需求。如果你的网站不需要考虑图片顺序,我个人认为这种方法是完美的。
注意,当你在包含太多元素的列表中使用 container-visibility 时,它会导致布局和渲染计算不断进行,这会使网站卡顿,性能不佳。通常,对于大型列表,程序员不会使用 container-visibility,最流行的两个选项是分页或使用延迟加载。

相关推荐
菜鸟小芯20 小时前
【腾讯位置服务开发者征文大赛】校园美食雷达 —— 基于 CodeBuddy + 腾讯 LBS 开发实战
前端·美食
搜狐技术产品小编202320 小时前
深度解析与业务实战:将 screenshot-to-code 改造为支持 React + Ant Design 的前端利器
前端·javascript·react.js·前端框架·ecmascript
Rik20 小时前
Cursor Rules 深度玩法:从全局配置到项目级规则,让 AI 真正理解你的项目
前端·后端
weixin_4713830320 小时前
set和map结构,减少O(n)复杂度
前端·javascript
hunteritself21 小时前
GPT Image2 + Seedance 2.0:3 小时从剧本到 AI 互动影游,深度实测复盘
前端·数据库·人工智能·深度学习·transformer
独秀不如众秀21 小时前
前端页面引擎协议:由浅入深——从 30 行到 vform3 的演化之路
前端
学网安的肆伍21 小时前
【044-WEB攻防篇】PHP应用&SQL盲注&布尔回显&延时判断&报错处理&增删改查方式
前端·sql·php
八号当铺21 小时前
从 Prompt 到 AI 工程化:理解 Rules、Skills 与 Agent
前端·ai编程·cursor
倒带人生21 小时前
将 $confirm 对话框改为 a-modal 实现的通用技术方案
javascript·ant design
didadida26221 小时前
子路径部署 Vue/React 应用偶发白屏
前端·后端