深入理解深入理解Vue 的条件渲染和列表渲染的条件渲染和列表渲染
这两天学习了Vue.js 感觉条件渲染和列表渲染知识点挺多的,而且很重要,所以,今天添加一点小笔记。
条件渲染条件渲染
v-if
在 < template > 中配合 v-if 渲染一整组
在使用 v-if 控制元素的时候,我们需要将它添加到这个元素上去。然而如果要切换很多元素的时候,一个个的添加就太麻烦
了。这时候就可以使用 < template > 将一组元素进行包裹,并在上面使用 v-if。最终的渲染结果不会包含 < template > 元素。
<template v-if="ok">
<h1>Title</h1>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
</template>
<script>
data:{
ok:true
}
</script>
我们更改 ok 的值,就可以控制整组的元素了
v-else
你可以使用 v-else 指令来表示 v-if 的“else 块”:
<div v-if="ok">
Now you see me
</div>
<div v-else>
Now you don't
</div>
v-else 元素必须紧跟在 v-if 或者 v-else-if 元素的后面——否则它将不会被识别。
v-else-if
v-else-if,顾名思义,充当 v-if 的“else-if 块”。可以链式地使用多次:
<div>
<p v-if="sc>=90">优秀</p>
<p v-else-if="sc>=60">及格</p>
<p v-else="sc<60">不及格</p>
</div>
类似于 v-else,v-else-if 必须紧跟在 v-if 或者 v-else-if 元素之后。
可复用元素可复用元素
Vue 会尽可能高效地渲染元素,通常会复用已有元素而不是从头开始渲染。这么做,除了使 Vue 变得非常快之外,还有一些
有用的好处。例如,如果你允许用户在不同的登录方式之间切换:
<div class="exp">
<template v-if="loginType === 'username'">
<label>Username</label>
<input placeholder="Enter your username">
</template>
<template v-else>
<label>Email</label>
<input placeholder="Enter your email address">
</template>
<input type="button" @click="btn" value="切换"/>
</div>