Vue的`v-if`和`v-show`用于条件渲染,`v-if`按需编译/销毁DOM,适合不频繁切换且节省初始化资源

简介: 【6月更文挑战第25天】Vue的`v-if`和`v-show`用于条件渲染,`v-if`按需编译/销毁DOM,适合不频繁切换且节省初始化资源;`v-show`则始终编译,仅通过CSS切换显示,适合频繁切换,初始渲染成本高但切换性能好。选择取决于元素显示状态的变化频率和初始渲染需求。

Vue.js 中的 v-ifv-show 指令都可以用来根据条件控制元素的显示与隐藏,但它们在实现机制、渲染过程和性能消耗上有所不同:

  1. 渲染时机与编译过程

    • v-if:这是一种“真正”的条件渲染,它会根据表达式的值来决定是否编译并渲染元素及其包含的子组件。当条件为 false 时,不会渲染任何内容,对应的DOM节点也不会被添加到文档中;当条件变为 true 时,才会开始渲染该部分的内容。
    • v-show:不论初始条件如何,该指令控制的元素总是会被编译并渲染到DOM中,只是通过CSS样式(通常是将display属性设置为none)来隐藏元素。当条件改变时,它并不销毁或重建DOM,而是简单地切换元素的display属性以展示或隐藏。
  2. 性能开销

    • v-if:由于它是条件性的编译/销毁 DOM 元素,因此初始渲染没有元素时消耗较少,但在条件切换时如果需要创建或销毁元素,则会有更高的开销,尤其是对于复杂的元素结构。
    • v-show:初始渲染时无论条件如何都会创建元素,所以有较高的初始渲染成本,但由于只是简单的切换CSS样式,所以在频繁切换显示状态时,相对于 v-if 来说性能损耗较小。
  3. 使用场景建议

    • 当一个元素可能不会经常切换显示状态或者初始化时就不应该渲染时,使用 v-if 更合适。
    • 如果某个元素需要频繁切换显示状态并且初始化时就应该被渲染出来,那么使用 v-show 可能是更好的选择,因为它避免了反复的DOM操作。例如,在做动画效果或只需简单显示/隐藏时,使用 v-show 较为适合。

总结来说,v-if 是用于条件性地执行DOM更新,强调的是是否渲染;而 v-show 则始终渲染元素,只是简单地切换元素可见性。

相关文章
|
18天前
|
JavaScript 前端开发 Go
CSS 与 JS 对 DOM 解析和渲染的影响
【10月更文挑战第16天】CSS 和 JS 会在一定程度上影响 DOM 解析和渲染,了解它们之间的相互作用以及采取适当的优化措施是非常重要的。通过合理的布局和加载策略,可以提高网页的性能和用户体验,确保页面能够快速、流畅地呈现给用户。在实际开发中,要根据具体情况进行权衡和调整,以达到最佳的效果。
|
2月前
|
JavaScript 前端开发 容器
用HTML DOM实现有条件地渲染网页元素(上)
用HTML DOM实现有条件地渲染网页元素(上)
|
2月前
|
存储 JavaScript 前端开发
用HTML DOM实现有条件地渲染网页元素(下)
用HTML DOM实现有条件地渲染网页元素(下)
|
30天前
|
JavaScript
在Vue中获取DOM元素的实际宽高
【10月更文挑战第2天】
191 1
|
2月前
|
JavaScript 前端开发
react字符串转为dom标签,类似于Vue中的v-html
本文介绍了在React中将字符串转换为DOM标签的方法,类似于Vue中的`v-html`指令,通过使用`dangerouslySetInnerHTML`属性实现。
77 0
react字符串转为dom标签,类似于Vue中的v-html
|
3月前
|
移动开发 JavaScript 前端开发
【Vue面试题二十二】、什么是虚拟DOM?如何实现一个虚拟DOM?说说你的思路
这篇文章深入探讨了虚拟DOM的概念、必要性以及在Vue中的实现方式,解释了虚拟DOM如何作为真实DOM的轻量级抽象,通过优化DOM操作提高性能,并实现跨平台渲染的能力。
【Vue面试题二十二】、什么是虚拟DOM?如何实现一个虚拟DOM?说说你的思路
|
3月前
|
JavaScript 算法 前端开发
"揭秘虚拟DOM的神奇魔法:从零开始打造高效渲染引擎,颠覆你的DOM操作认知!"
【8月更文挑战第20天】虚拟DOM是一种优化技术,通过在内存中构建DOM树的轻量级副本,减少浏览器重排和重绘,提升性能。本文简要介绍了DOM及其重要性,并深入解释了虚拟DOM的概念。虚拟DOM通过模拟真实DOM结构,在内存中进行数据更新,仅将变动部分同步到实际DOM。文中还提供了一个简易虚拟DOM的实现方案,包括虚拟节点创建、渲染函数及一个基本的diff算法,用于比对新旧虚拟DOM并高效更新实际DOM。通过示例展示了如何构建和渲染一个简单的虚拟DOM。这有助于理解虚拟DOM的基本工作原理和技术细节。
49 4
|
4月前
|
移动开发 JavaScript 前端开发
VUE实现一个列表清单【props 父子组件通信、slot插槽的使用、全局自定义指令的封装、$nextTick解决异步DOM更新、巧用v-model简化父子组件之间的通信、触发事件的事件源event】
VUE实现一个列表清单【props 父子组件通信、slot插槽的使用、全局自定义指令的封装、$nextTick解决异步DOM更新、巧用v-model简化父子组件之间的通信、触发事件的事件源event】
42 0
|
1月前
|
JavaScript
DOM 节点列表长度(Node List Length)
DOM 节点列表长度(Node List Length)
|
17天前
|
JavaScript
HTML DOM 节点树
HTML DOM 节点是指在 HTML 文档对象模型中,文档中的所有内容都被视为节点。整个文档是一个文档节点,每个 HTML 元素是元素节点,元素内的文本是文本节点,属性是属性节点,注释是注释节点。DOM 将文档表示为节点树,节点之间有父子和同胞关系。