VUE3v-if、v-for、v-show的理解

简介: VUE3v-if、v-for、v-show的理解

在 Vue 3 中,v-if、v-for 和 v-show 是三种常用的指令,它们分别用于条件渲染、列表渲染和元素显示隐藏。


1.v-if

v-if 是一个条件渲染指令,它会根据表达式的真假值来动态地添加或移除元素。如果表达式的值为真,则元素会被添加到 DOM 中;如果为假,则元素会被从 DOM 中移除。v-if 可以与 v-else 和 v-else-if 一起使用,以处理多个条件的情况。


示例:


<template>  
  <div>  
    <p v-if="showElement">这是一个显示的元素。</p>  
    <p v-else>这是一个备选元素。</p>  
  </div>  
</template>  
 
<script>  
export default {  
  data() {  
    return {  
      showElement: true  
    }  
  }  
}  
</script>


v-for

v-for 是一个列表渲染指令,它用于遍历数组或对象的属性,并为每个元素或属性生成一个模板的副本。通过 v-for,你可以轻松地在 Vue 组件中渲染列表或集合。


示例:


<template>  
  <div>  
    <p v-for="(item, index) in items" :key="index">{{ item }}</p>  
  </div>  
</template>  
 
<script>  
export default {  
  data() {  
    return {  
      items: ['Apple', 'Banana', 'Cherry']  
    }  
  }  
}  
</script>

1.v-show

v-show 指令用于控制元素的显示或隐藏。与 v-if 不同,v-show 不会从 DOM 中移除元素,而是通过改变元素的 CSS 属性 display 来实现显示和隐藏的效果。因此,即使元素被隐藏,它仍然会保留在 DOM 中。


示例:


<template>  
  <div>  
    <p v-show="isVisible">这个元素会根据 isVisible 的值显示或隐藏。</p>  
  </div>  
</template>  
 
<script>  
export default {  
  data() {  
    return {  
      isVisible: true  
    }  
  }  
}  
</script>

v-if 和 v-show 的区别:


  • 实现方式:v-if 是真正的条件渲染,它会根据条件动态地向 DOM 树添加或移除元素;而 v-show 只是简单地切换元素的 CSS 属性 display。
  • 编译与性能:v-if 有局部编译/卸载过程,当条件变化时,会销毁和重建内部的事件监听和子组件,因此切换开销较大;而 v-show 初始渲染后只会控制 CSS,性能相对较好。
  • 初始渲染与切换消耗:v-show 的初始渲染消耗较高,因为即使元素隐藏也会渲染到 DOM 中;而 v-if 的切换消耗较高,因为涉及到元素的添加和移除。


在选择使用 v-if 还是 v-show 时,需要根据具体场景和需求进行权衡。如果元素频繁地显示和隐藏,且对性能要求较高,通常使用 v-show;如果元素不常变化,或者需要在条件不满足时完全移除元素,可以使用 v-if。


相关文章
|
4天前
|
JavaScript
在vue中,v-show 与 v-if 有什么区别?
在vue中,v-show 与 v-if 有什么区别?
25 4
|
7月前
|
JavaScript API
Vue3 set up 的使用
Vue3 set up 的使用
|
4天前
|
JavaScript 前端开发
Vue中的v-show和v-if有什么区别?
Vue中的v-show和v-if有什么区别?
64 4
|
4天前
|
缓存 JavaScript 前端开发
【Vue】v - if与v - show的区别【超详细版】
【Vue】v - if与v - show的区别【超详细版】
|
4天前
|
JavaScript 算法 前端开发
Vue中的 v-show 和 v-if 的区别
Vue中的 v-show 和 v-if 的区别
30 2
|
10月前
|
JavaScript 前端开发
【Vue】 通过一个小BUG,让我对 v-if 和 v-show产生的疑虑
鄙人是个比较菜的新手。用React比较多,当然哈,只限于使用..... 不绕弯子了,之前早就关注过 v-if 和 v-show 的区别,打死我也没想到因为这俩还给我整出了bug。
|
6月前
|
JavaScript 前端开发
vue中v-if与v-show的区别
vue中v-if与v-show的区别
19 0
|
9月前
|
JavaScript 前端开发
vue中v-if和v-show的区别
v-if 是“真正”的条件渲染,因为它会确保在切换过程中条件块内的事件监听器和子组件适当地被销毁和重建。 v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做——直到条件第一次变为真时,才会开始渲染条件块。 相比之下,v-show 就简单得多——不管初始条件是什么,元素总是会被渲染,并且只是简单地基于 CSS 进行切换。
37 0
|
9月前
|
JavaScript
Vue中的v-if与v-show有什么区别 分别在什么时候使用
Vue中的v-if与v-show有什么区别 分别在什么时候使用
|
9月前
|
JavaScript 前端开发
vue中v-if与v-show的优缺点
在Vue中,`v-if`和`v-show`是用于条件性地显示或隐藏元素的指令。