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)); /* 小屏幕时调整最小宽度 */
  }
}
相关推荐
吴声子夜歌12 分钟前
ES6——Iterator和for...of循环详解
前端·javascript·es6
小李子呢021116 分钟前
前端八股3---ref和reactive
开发语言·前端·javascript
落魄江湖行20 分钟前
基础篇三 Nuxt4 组件进阶:插槽与事件传递
前端·nuxt4
kerli21 分钟前
Compose 组件:LazyColumn 核心参数与 key/contentType 详解
android·前端
好运的阿财22 分钟前
“锟斤拷”问题——程序中用powershell执行命令出现中文乱码的解决办法
linux·前端·人工智能·机器学习·架构·编辑器·vim
踩着两条虫33 分钟前
VTJ.PRO AI + 低代码实战:接入高德地图
前端·vue.js·ai编程
绝世唐门三哥34 分钟前
React性能优化:memo、useMemo和useCallback全解析
前端·react.js·memo
兔子零102436 分钟前
Claude Code 都把宠物养进终端了,我做了一个真正能长期玩的中文宠物游戏
前端·游戏·游戏开发
xiaotao13136 分钟前
Vite 与 Webpack 开发/打包时环境变量对比
前端·vue.js·webpack
摆烂工程师41 分钟前
教你如何查询 Codex 最新额度是多少,以及 ChatGPT Pro、Plus、Business 最新额度变化
前端·后端·ai编程