美文网首页让前端飞Vue.js的学习过程与心得前端
Vue条件渲染(v-if和v-show的区别)

Vue条件渲染(v-if和v-show的区别)

作者: honey缘木鱼 | 来源:发表于2018-12-27 14:53 被阅读2次

    在项目中我们总是用到根据某一值判断属性是否显示,或不同的值让其显示不同,顾名思义总是用v-if来实现,v-show也可用来判断是否显示,两者有什么区别呢?

    相同点:两者都可用作为条件判断元素是否显示。

    不同点:1). v-if后可跟v-else-ifv-else用来进行不同条件下的显示组件的不同可能性,v-show只能作为是否展示。
    2). v-if在想切换多个元素时把一个 <template> 元素当做不可见的包裹元素上使用,v-show不能用<template> 元素

    <template v-if="ok">
      <h1>Title</h1>
      <p>Paragraph 1</p>
      <p>Paragraph 2</p>
    </template>
    

    3).v-if 在条件切换过程中,事件监听器和子组件适当地被销毁和重建。

    4). v-if条件为真才会渲染,条件为假则不渲染,v-show 无论条件真假总会渲染,只是简单地基于 CSS 进行切换。

    一般来说,v-if 有更高的切换开销,而 v-show 有更高的初始渲染开销。因此,如果需要非常频繁地切换,则使用 v-show 较好;如果在运行时条件很少改变,则使用 v-if 较好。

    相关文章

      网友评论

        本文标题:Vue条件渲染(v-if和v-show的区别)

        本文链接:https://www.haomeiwen.com/subject/duirlqtx.html