Vue 的 v-if 与 v-show,Android 的 GONE 与 INVISIBLE

Vue 的 v-if 与 v-show,Android 的 GONE 与 INVISIBLE

在界面开发中,控制元素的显示和隐藏是最常见的需求之一。今天我们来聊聊 Vue.js 和 Android 中这两对"显示隐藏"控制器的异同,看看不同技术栈如何解决相似的问题。

🆚 核心对比:四个关键特性

特性 Vue v-if Vue v-show Android GONE Android INVISIBLE
渲染机制 条件为假时完全销毁元素 始终渲染,只设置 display: none不可见不占位 从布局中完全移除 保留在布局中,不可见但占位
性能影响 切换时开销大,适合不频繁切换 只有 CSS 切换开销,适合频繁切换 会触发重新布局 不会触发重新布局
内存占用 不显示时不占用内存 始终占用内存 不占用布局资源 占用布局资源
生命周期 触发完整生命周期钩子 不触发生命周期 触发视图的附加/分离 视图状态不变

🔧 工作原理简析

Vue 的实现

vue 复制代码
<!-- v-if:条件为假时,元素从 DOM 中完全移除 -->
<div v-if="isVisible">我会被销毁/重建</div>

<!-- v-show:只是添加/移除 CSS 的 display 属性 -->
<div v-show="isVisible">我始终在 DOM 中,只是隐藏了</div>

Android 的实现

kotlin 复制代码
// GONE:完全从布局中移除,不占空间
view.visibility = if (isVisible) View.VISIBLE else View.GONE

// INVISIBLE:不可见,但仍占着原来的位置
view.visibility = if (isVisible) View.VISIBLE else View.INVISIBLE

🎯 使用场景指南

什么时候用 v-if / GONE?

适合场景

  • 权限控制组件(如管理员面板)
  • 一次性弹窗/对话框
  • 初始加载时不需渲染的内容
  • 组件较重,隐藏时可释放内存

代码示例

vue 复制代码
<!-- Vue:管理员功能,普通用户不需要渲染 -->
<admin-panel v-if="user.role === 'admin'" />

<!-- Android:根据网络状态切换视图 -->
if (isOnline) {
    onlineView.visibility = View.VISIBLE
    offlineView.visibility = View.GONE
}

什么时候用 v-show / INVISIBLE?

适合场景

  • Tab 切换内容
  • 下拉菜单/折叠面板
  • 需要保持组件状态(如表单数据)
  • 频繁显示/隐藏的动画元素

代码示例

vue 复制代码
<!-- Vue:Tab 切换,保持组件状态 -->
<div v-show="activeTab === 'home'">首页内容</div>
<div v-show="activeTab === 'profile'">个人资料</div>
kotlin 复制代码
// Android:加载状态,避免布局跳动
progressBar.visibility = if (isLoading) View.VISIBLE else View.INVISIBLE

💡 一句话总结

  • v-ifGONE:不显示时完全移除,节省内存但切换开销大
  • v-showINVISIBLE:只是隐藏,切换快但始终占用资源

🤔 如何选择?

记住这个简单的决策流程:

复制代码
需要控制显示/隐藏吗?
    ↓
是否频繁切换?
    ↓
是 → 用 v-show / INVISIBLE
否 → 用 v-if / GONE
    ↓
组件很重吗?    是 → 倾向用 v-if / GONE
    ↓
需要保持状态吗?  是 → 倾向用 v-show / INVISIBLE

🌟 总结

虽然 Vue 和 Android 是两种完全不同的技术栈,但在解决"显示隐藏"这个问题上,它们的思路是相通的:

  • 彻底移除(v-if / GONE)适合不频繁切换、需要节省资源的场景
  • 单纯隐藏(v-show / INVISIBLE)适合频繁切换、需要保持状态的场景
相关推荐
原则猫31 分钟前
HOOKS 背后机制
前端
码语智行38 分钟前
首页导航跳转功能深度解析-系统内和系统外
前端
阿猫的故乡1 小时前
Vue过渡动画从入门到装X:淡入淡出、滑动、列表动画、第三方库全搞定
前端·javascript·vue.js
裕波2 小时前
Vue&ViteConf 2026 将于 7 月 18 日在上海举办,尤雨溪将现场发表主题演讲
vue.js·vite
IManiy2 小时前
总结之Vibe Coding前端骨架
前端
JS菌2 小时前
AI Agent 沙箱双层防护体系:从权限过滤到内核隔离的完整实现
前端·人工智能·后端
Aphasia3112 小时前
从输入URL到页面展示全流程
前端·面试
黄林晴2 小时前
Google Play 发版链路全面重构:合规前置、审核自动化、生态全面收紧
android·google
我叫黑大帅2 小时前
前端如何竖屏固定视口背景
前端·javascript·面试
abcy0712132 小时前
python pandas csv异步后台清洗前端优先返回成功信息
前端·python·pandas