flex布局和grid布局区别,实现两边固定布局中间自适应

一、Flex 和 Grid 的核心区别(先给结论)

一句话区别(面试直接说)

Flex 是一维布局(行或列),Grid 是二维布局(行 + 列)。


二、Flex vs Grid 对比表(必背)

维度 Flex Grid
布局维度 一维 二维
控制方向 主轴 / 交叉轴 行 / 列
是否适合整体布局 一般 非常适合
内容驱动
布局精确度 一般
响应式

三、什么时候用 Flex?什么时候用 Grid?

用 Flex 的场景

  • 列表

  • 导航栏

  • 单行 / 单列布局

  • 内容自适应为主


用 Grid 的场景

  • 页面整体结构

  • 后台系统

  • 仪表盘

  • 多行多列精确布局


四、两边固定,中间自适应 ------ 三种实现方式 ⭐


方案一:Flex(最常用,面试推荐)

HTML

复制代码
<div class="container">
  <div class="left">左</div>
  <div class="center">中</div>
  <div class="right">右</div>
</div>

CSS

复制代码
.container {
  display: flex;
}

.left,
.right {
  width: 200px;
}

.center {
  flex: 1;
}

原理

  • 左右固定宽度

  • 中间 flex: 1 占剩余空间


方案二:Grid(最优雅,现代推荐)⭐

CSS

复制代码
.container {
  display: grid;
  grid-template-columns: 200px 1fr 200px;
}

优点

  • 代码最少

  • 布局最清晰

  • 语义直观


方案三:传统定位(兼容老项目)

复制代码
.left {
  float: left;
  width: 200px;
}

.right {
  float: right;
  width: 200px;
}

.center {
  margin: 0 200px;
}

❌ 不推荐新项目


五、Flex vs Grid 实现对比总结

方案 推荐度 特点
Flex ⭐⭐⭐⭐ 灵活、兼容好
Grid ⭐⭐⭐⭐⭐ 结构清晰
float 维护成本高

六、面试官常追问(提前准备)

1️⃣ 为什么 Grid 更适合整体布局?

  • 原生二维

  • 不依赖内容顺序

  • 精确控制行列


2️⃣ Flex 的 flex: 1 本质?

复制代码
flex: 1 1 0%;

3️⃣ Grid 的 fr 是什么?

  • 剩余空间比例单位

七、30 秒面试标准回答(直接背)

Flex 是一维布局,适合线性结构;Grid 是二维布局,更适合整体页面结构。

两边固定中间自适应可以用 Flex 的 flex: 1,也可以用 Grid 的 200px 1fr 200px,Grid 方案更清晰。


八、一句话终极总结

布局复杂用 Grid,线性排列用 Flex。


相关推荐
春风得意之时15 小时前
前端安装项目出现代理问题和ssl认证问题
前端·网络协议·ssl
问心无愧051315 小时前
ctf show web入门109
android·前端·笔记
Java.熵减码农15 小时前
Hermes Agent 安装踩坑记录:DNS 解析失败 & Node.js 幽灵文件冲突
node.js·ai编程·hermes
粉末的沉淀15 小时前
vue:Vite项目中高效管理纯色SVG图标的方案
前端·javascript·vue.js
xyz_CDragon15 小时前
OpenClaw 局域网调用 Ollama 本地大模型:完整配置与踩坑指南
python·ai编程·集成学习·ollama·deepseek·openclaw
dotnet9015 小时前
PDF 页面尺寸上限是 14400。iText 直接加载成功的大图可能超过这个限制,需要在 setPageSize 之前等比缩放。
前端·javascript·html
threelab15 小时前
Three.js 几何图形变换 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
道友可好15 小时前
写给 AI 的入职手册,AGENTS.md
前端·人工智能·后端
吠品15 小时前
处理 Python 类继承中那些变来变去的初始化参数
linux·前端·python
云水一下15 小时前
TypeScript 从零基础到精通(七):从配置到全栈项目落地
前端·javascript·typescript