CSS Grid 和 Flexbox 的核心区别在于布局维度:Grid 是二维布局(同时控制行与列),Flexbox 是一维布局(一次只能控制行或列),二者适用场景完全不同。
核心区别对比
对比维度 Flexbox(弹性布局) CSS Grid(网格布局)
布局维度 一维(行 OR 列,需先定义 flex-direction ) 二维(行 AND 列,直接定义网格结构)
控制核心 侧重"项目在轴线方向上的对齐与分配"(如space-between) 侧重"整个网格的结构划分"(先画格子,再放项目)
适用场景 - 简单的横向/纵向排列(如导航栏、按钮组) - 项目在单行/单列内的对齐、均分 - 内容不确定时的自适应(如卡片内文字垂直居中) - 复杂的整体页面框架(如"header+侧边栏+main+footer") - 固定行列的网格布局(如图片墙、商品卡片网格) - 项目需要跨行列排列(如某卡片占2行3列)
简单来说:"一维排不齐,用Flex;二维要规划,用Grid",二者可结合使用(如 Grid 定义页面框架,Flex 处理框架内单个模块的对齐)