上一篇 介绍了通过vue.js绑定class和style样式,这次我们一起学习vue.js中的条件渲染。
- v-if指令(这个前面介绍过)
<h1 v-if="ok">Yes</h1>
- v-else
<h1 v-if="ok">Yes</h1>
<h1 v-else>No</h1>
因为 v-if是一个指令,需要将它添加到一个元素上。但是如果我们想切换多个元素呢?此时我们可以把一个 <template>元素当做包装元素,并在上面使用 v-if,最终的渲染结果不会包含它。
<template v-if="ok">
<h1>Title</h1>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</template>
- v-if中也可以添加js内置函数,如:
<div v-if="Math.random() > 0.5">
Sorry
</div>
<div v-else>
Not sorry
</div>
注意:v-else元素必须立即跟在 v-if元素的后面——否则它不能被识别。
- v-show
v-show的用法和实现效果和v-if基本一样
<h1 v-show="ok">Hello!</h1>
不同的是有 v-show的元素会始终渲染并保持在 DOM 中。v-show是简单的换元素的 CSS 属性 display,而且v-show不支持 <template>语法。
- 最后是v-if和v-else的比较
在切换 v-if 块时,Vue.js 有一个局部编译/卸载过程,因为 v-if 之中的模板也可能包括数据绑定或子组件。v-if 是真实的条件渲染,因为它会确保条件块在切换当中合适地销毁与重建条件块内的事件监听器和子组件。
v-if 也是惰性的:如果在初始渲染时条件为假,则什么也不做——在条件第一次变为真时才开始局部编译(编译会被缓存起来)。
相比之下,v-show 简单得多——元素始终被编译并保留,只是简单地基于 CSS 切换。
一般来说,v-if 有更高的切换消耗而 v-show 有更高的初始渲染消耗。因此,如果需要频繁切换 v-show 较好,如果在运行时条件不大可能改变 v-if 较好。
列表渲染是在网页中非常常见的功能,我们大多数时候都在与其打交道,下篇文章我们将一起学习vue.js中的更多的关于列表的操作。