display: none使元素脱离文档流且不占空间,布局重排;visibility: hidden保留空间,布局不变,仅视觉隐藏。

在HTML和CSS中,隐藏元素常用的方法是使用 display: none 和 visibility: hidden。虽然它们都能让元素“看不见”,但行为上有本质区别。
display: none 的用法与特点
将元素的 display 属性设置为 none,会使该元素完全从文档流中移除:
- 元素不占据任何空间
- 页面布局会重新调整,就像这个元素不存在一样
- 子元素也会一同被隐藏
- 无法触发事件(如点击、鼠标移入等)
.hide-by-display {
display: none;
}
常用于需要彻底隐藏且不影响布局的场景,比如切换标签页时隐藏非当前内容。
visibility: hidden 的用法与特点
将 visibility 设置为 hidden,元素只是不可见,但仍保留在文档流中:
立即学习“前端免费学习笔记(深入)”;
- 元素保留原有空间和位置
- 页面布局不会发生变化
- 子元素即使设置 visibility: visible 也无法显示(被父级隐藏覆盖)
- 仍可能响应某些事件(取决于具体实现)
.hide-by-visibility {
visibility: hidden;
}
适合用于暂时隐藏但需保持布局结构的情况,例如制作闪烁动画或占位隐藏。
主要区别总结
| 特性 | display: none | visibility: hidden |
|---|---|---|
| 是否占据空间 | 否 | 是 |
| 是否脱离文档流 | 是 | 否 |
| 子元素能否显示 | 不能 | 不能(除非 visibility 被重置) |
| 对布局的影响 | 有,布局重排 | 无,布局不变 |
如何选择使用哪种方式?
根据实际需求判断:
- 想让元素彻底“消失”并释放空间 → 用 display: none
- 只想让人看不见但保留位置 → 用 visibility: hidden
- 需要动画控制显隐 → visibility 更适合淡出效果;display 不支持过渡动画
基本上就这些。理解两者的差异,能帮助你在开发中更精准地控制页面表现。











