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)); /* 小屏幕时调整最小宽度 */
  }
}
相关推荐
全栈陈序员7 分钟前
前端文件下载常用方式详解
前端·javascript·chrome·ajax·css3·html5·safari
Developer_Niuge22 分钟前
前端批量请求失败重复弹窗的正确解决方案
前端
前端小饭桌23 分钟前
告别嵌套地狱:用数据结构优化解决 JS 多层循环的混乱与静默错误
前端·javascript
爱摸鱼的格子24 分钟前
🚀 你真的会用 Promise.all 吗?10 个实用技巧助你成为异步处理大师!
前端
JacksonGao25 分钟前
React Fiber的调度算法你了解多少呢?
前端·react.js
这可不简单27 分钟前
方便易懂的自适应方案---echarts和dom样式大小自适应
前端·vue.js·echarts
玲小珑29 分钟前
Auto.js 入门指南(七)定时任务调度
android·前端
橘黄的猫30 分钟前
深入解析 import.meta.url:与 new URL() 的关系及 Vite 中的 base 路径影响
前端·vite
白瓷梅子汤31 分钟前
跟着官方示例学习 @tanStack-table --- Column Filters
前端·react.js
海的诗篇_34 分钟前
前端开发面试题总结-HTML篇
前端·面试·html