CSS【详解】给子元素添加间距的最佳实践(含space 和 gap 的区别图解和面试的标准答案)

space 和 gap 都能用于让子元素间产生间距,但实现原理和适用范围不同,推荐用 gap,不要用space

space-x / space-y gap
适用范围 可用于任意容器 仅用于flex/grid 容器
实现原理 space-x 是给第1至倒数第2个子元素添加 margin-right space-y 是给第1至倒数第2个子元素添加 margin-bottom 父容器内部创建「空隙」
作用对象 子元素 父容器自己
换行布局 会出问题(间距加倍) 完美支持
垂直+水平间距 需要同时写 space-x + space-y 只写 gap 就够
嵌套影响 会影响深层子元素 只影响直接子元素
兼容性 极老浏览器也支持 现代浏览器支持(几乎全覆盖)
推荐程度 仅用于简单单行 99% 场景推荐

换行的,space-x 与 gap 的区别

换行的,space-y 与 gap 的区别

面试标准答案

  • space-x/y 是通过给子元素添加 margin 实现间距,不支持换行布局,容易产生间距错乱;
  • gap 是 Flex/Grid 原生的容器间隙属性,支持自动换行,间距统一稳定,是现代布局的首选
相关推荐
云水一下3 小时前
TypeScript 从零基础到精通(五):高级类型与泛型
前端·javascript·typescript
counterxing3 小时前
vibe coding 之后,我更不想打字了
前端·agent·ai编程
copyer_xyf4 小时前
Python 模块与包的导入导出
前端·后端·python
研☆香4 小时前
es6新特性功能介绍(四)
前端·ecmascript·es6
微扬嘴角4 小时前
React篇1--JSX语法规则、组件、组件实例的3大特性
前端·react.js·前端框架
copyer_xyf4 小时前
Python venv 虚拟环境
前端·后端·python
无聊的老谢5 小时前
Vue 3 + TypeScript 构建大型电信运维平台的前端架构设计
前端·vue.js·typescript
xiaofeichaichai5 小时前
Map / Set / WeakMap / WeakSet
前端·javascript
李可以量化5 小时前
成交量的终极量化策略:价量共振指标完整实现(下篇)
前端·数据库·人工智能
copyer_xyf6 小时前
Python 如何同时做很多事:进程、线程、协程
前端·后端·python