css grid实现流体布局

虽然使用flex也可以实现流式布局,但是我觉得使用Grid实现布局更方便,也更好控制。

使用CSS Grid实现流式布局的步骤:

css 复制代码
<div class="grid-container">
  <div class="grid-item">1</div>
  <div class="grid-item">2</div>
  <div class="grid-item">3</div>
  <div class="grid-item">4</div>
  <div class="grid-item">5</div>
  <div class="grid-item">6</div>
  ...
</div>
css 复制代码
.grid-container {
  display: grid;
  // 规定网格布局中的列数(和宽度)
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); /* 定义列宽 */
  gap: 0px; /* 设置网格项之间的间隔 */
}

css解析

  1. repeat(重复次数, 轨道尺寸)
  2. auto-fill会根据可用空间自动填充尽可能多的列或行
  3. minmax(min, max)函数定义了列或行的最小和最大尺寸
  4. fr单位允许列宽根据可用空间动态调整

所以grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); 的意思就是满足每列最小200px的情况下自动调整列数填充尽可能多的列,填充尽可能多的列后剩余宽度再分配给每一列 ,假设屏幕宽度是900,填充后就是4列,每列宽度是200+(100/4) = 225, 前提是gap: 0px的情况下

还可以配合媒体查询实现响应式布局

css 复制代码
.grid-container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
}
 
@media (max-width: 600px) {
  .grid-container {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); /* 小屏幕时调整最小宽度 */
  }
}
相关推荐
ZC跨境爬虫3 小时前
跟着 MDN 学 HTML day_9:(信件语义标记)
前端·css·笔记·ui·html
前端老石人3 小时前
HTML 字符引用完全指南
开发语言·前端·html
幼儿园技术家4 小时前
前端如何设计权限系统(RBAC / ABAC)?
前端
前端摸鱼匠5 小时前
Vue 3 的v-bind合并行为:讲解v-bind与普通属性合并的规则
前端·javascript·vue.js·前端框架·ecmascript
REDcker5 小时前
浏览器端Web程序性能分析与优化实战 DevTools指标与工程清单
开发语言·前端·javascript·vue·ecmascript·php·js
donecoding7 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马7 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren7 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川7 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端