v-if v-else v-show

v-if v-show都是靠后面的值来决定是否显示的

  • v-if 的特点:每次都会重新删除或创建元素
  • v-show 的特点: 每次不会重新进行DOM的删除和创建操作,只是切换了元素的 display:none 样式

  • v-if 有较高的切换性能消耗
  • v-show 有较高的初始渲染消耗

代码演示demo:



    
        
        v-text与v-html在v-bind上的使用
        
    
    
        
显示 不显示

v-else

你可以使用 v-else 指令来表示 v-if 的“else 块”:

Now you see me
Now you don't

v-else 元素必须紧跟在带 v-if 或者 v-else-if 的元素的后面,否则它将不会被识别。

v-else-if

v-else-if,顾名思义,充当 v-if 的“else-if 块”,可以连续使用:

A
B
C
Not A/B/C

类似于 v-elsev-else-if 也必须紧跟在带 v-if 或者 v-else-if 的元素之后。

key 管理可复用的元素

Vue 会尽可能高效地渲染元素,通常会复用已有元素而不是从头开始渲染。这么做除了使 Vue 变得非常快之外,还有其它一些好处。例如,如果你允许用户在不同的登录方式之间切换:



那么在上面的代码中切换 loginType 将不会清除用户已经输入的内容。因为两个模板使用了相同的元素, 不会被替换掉——仅仅是替换了它的 placeholder

这样也不总是符合实际需求,所以 Vue 为你提供了一种方式来表达“这两个元素是完全独立的,不要复用它们”。只需添加一个具有唯一值的 key attribute 即可:如下.



注意,

详情请看Vue官方文档https://cn.vuejs.org/v2/guide/conditional.html#v-else

v-ifv-for 一起使用


不推荐同时使用 v-ifv-for。请查阅风格指南关于v-if和v-for联用的劝解以获取更多信息。

v-ifv-for 一起使用时,v-for 具有比 v-if 更高的优先级。请查阅列表渲染指南以获取详细信息。

你可能感兴趣的:(v-if v-else v-show)