当前位置: 首页 > news >正文

Vue中v-show与v-if的区别

1、渲染机制不同

  • v-if
    • 惰性渲染: 初始化条件为false不会渲染元素到DOM。
    • 切换时: 条件变化会销毁/重建组件/元素(触发生命周期钩子)。
    • 支持template标签和v-else/v-else-if
  • v-show
    • 始终渲染: 无论条件如何,元素始终存在于DOM中。
    • 切换时: 仅通过 CSS 的display: none控制显示/隐藏(无生命周期变化)。

2、性能对比

  • v-if 切换成本高
    适合不频繁切换的场景(如初始化渲染决定是否显示)。
<div v-if="isExpensive">耗性能的内容(如复杂组件)</div>
  • v-show 初始化成本高
    适合频繁切换的场景(如选项卡切换)。
<div v-show="isActive">频繁切换的内容</div>

3、生命周期影响

  • v-if
    条件为true时触发mounted等钩子;为false时触发unmounted
  • v-show
    无论条件如何,组件的生命周期不会重新触发

4、使用场景示例

场景推荐指令原因
初始加载时决定是否显示v-if避免渲染不需要的DOM节点
频繁切换显示状态(如菜单)v-show避免重复销毁/重建的性能损耗
涉及高开销组件v-if减少不必要的初始化开销

总结表格
|特性|v-if|v-show|
|初始渲染|条件为真才渲染|总是渲染|
|切换开销|高(销毁/重建)|低(CSS切换)|
|生命周期|触发钩子|不触发|
|DOM 存在性|条件为假时移除|始终存在(隐藏)|
|适用场景|不频繁切换|频繁切换|

简单记忆:

  • 需要减少初始负载 → v-if
  • 需要快速切换显示 → v-show
http://www.dtcms.com/a/336149.html

相关文章:

  • 【AI论文】序曲(PRELUDE):一项旨在考察对长文本语境进行全局理解与推理能力的基准测试
  • C语言私人学习笔记分享
  • STM32单片机学习日记
  • 第四章:大模型(LLM)】06.langchain原理-(7)LangChain 输出解析器(Output Parser)
  • 模型提取的相关经验
  • 库制作与原理(下)
  • 端到端测试:复杂系统的终极体检术
  • 【C2000】德州仪器C2000产品开发板的原理图如何找到?
  • 反向代理、负载均衡器与API网关选型决策
  • 《MutationObserver深度解构:重塑自动化视觉回归测试的底层逻辑》
  • B站 韩顺平 笔记 (Day 21)
  • [python学习记录2]变量
  • 【Unity3D实例-功能-拔枪】角色拔枪(二)分割上身和下身
  • vue封装请求拦截器 响应拦截器
  • 定时器输出PWM波配置(呼吸灯)
  • 平行双目视觉-动手学计算机视觉18
  • C++ Building Blocks 构建块 Or 构件块
  • SVN客户端下载与安装
  • 「数据获取」《中国教育统计年鉴》(1949-2023)(获取方式看绑定的资源)
  • 【嵌入式基础知识梳理#11】Modbus-RTU工业总线协议
  • Spring IOC 学习笔记
  • Canny边缘检测
  • Python异步编程实战:爬虫案例
  • 【Python】-- 机器学习项目 - 基于KNN算法的鸢尾花分类
  • 【自动化运维神器Ansible】Playbook中的when条件判断:精细化控制任务执行
  • 【Linux系列】常见查看服务器 IP 的方法
  • Python 基本语法(二)
  • 数据结构初始知识
  • 利用标准IO实现寻找文件中字符出现最多次数
  • 问津集 #5:Crystal: A Unified Cache Storage System for Analytical Databases