v-if、v-show、display: none、visibility: hidden区别

区别

指令/属性 行为本质 是否占据空间 DOM 状态 事件响应
v-if 条件为 false 时销毁 DOM 元素,条件为 true 时重新创建 ❌ 不占据 元素从 DOM 移除 ❌ 无
v-show 通过 CSS display: none 切换显示/隐藏 ❌ 不占据 元素保留在 DOM ❌ 无
display: none 元素完全隐藏且不占据空间,但仍存在于 DOM 中 ❌ 不占据 元素保留在 DOM ❌ 无
visibility: hidden 元素不可见但保留布局空间,仍存在于 DOM 中 ✅ 占据 元素保留在 DOM ✅ 有

使用场景

需求 推荐方案 原因
条件不频繁变化 v-if 或 display: none 减少初始 DOM 节点,节省资源
条件频繁切换 v-show 避免重复渲染 DOM,切换更流畅
保留布局空间 visibility: hidden 隐藏元素但保留空间,避免布局抖动
需要事件穿透 visibility: hidden + 事件监听 元素不可见但可交互(需额外处理事件逻辑)

v-if 和 display: none 在"隐藏且不占据空间"的行为上相似,但 v-if 更彻底(销毁 DOM)。

v-show 实际使用 display: none,与 visibility: hidden 无关。

根据具体场景(是否频繁切换、是否需要保留空间)选择合适的方案,而非简单等价对应

相关推荐
阿蒙Amon1 小时前
TypeScript学习-第7章:泛型(Generic)
javascript·学习·typescript
睡美人的小仙女1271 小时前
Threejs加载环境贴图报错Bad File Format: bad initial token
开发语言·javascript·redis
fanruitian1 小时前
uniapp android开发 测试板本与发行版本
前端·javascript·uni-app
rayufo1 小时前
【工具】列出指定文件夹下所有的目录和文件
开发语言·前端·python
RANCE_atttackkk1 小时前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
摘星编程2 小时前
React Native + OpenHarmony:Timeline垂直时间轴
javascript·react native·react.js
2501_944525543 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
jin1233224 小时前
React Native鸿蒙跨平台完成剧本杀组队详情页面,可以复用桌游、团建、赛事等各类组队详情页开发
javascript·react native·react.js·ecmascript·harmonyos
李白你好4 小时前
Burp Suite插件用于自动检测Web应用程序中的未授权访问漏洞
前端
经年未远4 小时前
vue3中实现耳机和扬声器切换方案
javascript·学习·vue