[前端|vue] v-if 和v-show的区别,为什么功能会类似

v-ifv-show 都是 Vue 中用于条件渲染的指令,但它们之间存在几个关键区别,这些区别导致了它们在不同场景下的适用性也有所不同:

  1. v-if 的特点:

    条件渲染:v-if 是一个动态的条件渲染指令,它会根据表达式的值来决定是否渲染元素。如果条件为假,则元素及其内部的所有内容都不会被渲染到 DOM 中,这可以减少初始渲染时不必要的资源消耗。

    惰性渲染:v-if 是惰性的,如果初始条件为假,则什么也不做;只有在条件第一次变为真时才开始局部编译并渲染。这对于只在某些条件下才需要渲染的内容来说非常有用,可以提升初次加载性能。

    销毁与重建:当条件变化时,v-if 会销毁并重新创建条件块内的所有内容,包括组件实例、事件监听器等。这意味着每次条件变化时,相关的数据绑定和组件状态都会被重新初始化。

  2. v-show 的特点:

    切换显示:v-show 也是条件渲染指令,但它通过修改 CSS 的 display 属性(通常是 none 或 block)来控制元素的显示或隐藏,而不是像 v-if 那样控制元素的生成与销毁。元素始终会被渲染并保留在 DOM 中,只是简单地切换其可见性。

    初始渲染成本:v-show 在初始渲染时无论条件真假都会渲染元素,这使得它的初始渲染成本较高,但后续切换状态的成本较低,因为它只是改变了 CSS 样式。

    持续存在:由于元素始终存在于 DOM 中,即使初始时不可见,事件监听器和子组件的状态也会被保留,这对于频繁切换状态的场景较为友好,因为不需要反复创建和销毁元素。

  3. 功能类似的原因:

    尽管机制不同,v-if 和 v-show 的最终视觉效果很相似,都能实现根据条件展示或隐藏元素。选择哪一个取决于具体的使用场景和性能需求:

    如果条件很少改变且需要首屏渲染速度,或者需要根据条件控制组件生命周期,应使用 v-if。

    如果频繁切换显示状态,且初始渲染时间不是关键因素,或者希望保持组件状态不被销毁,应使用 v-show。

相关推荐
Setsuna_F_Seiei8 分钟前
AI 对话应用之页面滚动交互的实现
前端·javascript·ai编程
新缸中之脑31 分钟前
追踪来自Agent的Web 流量
前端
wefly20171 小时前
从使用到原理,深度解析m3u8live.cn—— 基于 HLS.js 的 M3U8 在线播放器实现
java·开发语言·前端·javascript·ecmascript·php·m3u8
英俊潇洒美少年1 小时前
vue如何实现react useDeferredvalue和useTransition的效果
前端·vue.js·react.js
英俊潇洒美少年2 小时前
ref 底层到底是怎么变成响应式的?
vue.js
kyriewen112 小时前
给浏览器画个圈:CSS contain 如何让页面从“卡成PPT”变“丝滑如德芙”
开发语言·前端·javascript·css·chrome·typescript·ecmascript
英俊潇洒美少年2 小时前
react19和vue3的优缺点 对比
前端·javascript·vue.js·react.js
多看书少吃饭4 小时前
Vue + Java + Python 打造企业级 AI 知识库与任务分发系统(RAG架构全解析)
java·vue.js·笔记
~无忧花开~4 小时前
React生命周期全解析
开发语言·前端·javascript·react.js·前端框架·react