深入理解Vue 的条件渲染和列表渲染

2020-06-14 06:01:02易采站长站整理

复制上面的代码,在自己的浏览器中试一试。

有时候我们不希望浏览器保留我们输入的内容,所以 Vue 为你提供了一种方式来声明“这两个元素是完全独立的——不要复用它们”。只需添加一个具有唯一值的 key 属性即可:


<template v-if="loginType === 'username'">
<label>Username</label>
<input placeholder="Enter your username" key="username">
</template>

<template v-else>
<label>Email</label>
<input placeholder="Enter your email address" key="email">
</template>

v-show

另一个用于根据条件展示元素的选项是 v-show 指令。用法大致一样:


<h1 v-show="ok">Hello!</h1>
<script>
data:{
ok:false
}
</script>

不同的是带有 v-show 的元素始终会被渲染并保留在 DOM 中。v-show 是简单地切换元素的 CSS 属性 display 。

渲染如下


<div style="display:none;"></div>

列表渲染

使用 v-for 把一个数组对应为一组元素

我们用 v-for 指令根据一组数组的选项列表进行渲染。 v-for 指令需要以 item in items 形式的特殊语法, items 是源数据数组并且 item 是数组元素迭代的别名。


<div class="exp">
<ul>
<li v-for="item in items">{{item.text}}</li>
</ul>
</div>

<script>
data:{
items:[
{text:"eat"},
{text:"play"},
{text:"game"}
] }
</script>

渲染结果


<div class="exp">
<ul>
<li>eat</li>
<li>play</li>
<li>game</li>
</ul>
</div>

v-for 还支持一个可选的第二个参数为当前项的索引。


<div class="exp">
<ul>
<li v-for="item,index in items">{{index}}-{{item.text}}</li>
</ul>
</div>
<script>
var exp=new Vue({
el:".exp",
data:{
items:[
{text:'eat'},
{text:'paly'},
{text:'game'}
] }
})
</script>

结果

0-eat
1-paly
2-game

一个对象的 v-for

你也可以用 v-for 通过一个对象的属性来迭代。


<div class="exp">
<ul>
<li v-for="value in obj">{{value}}</li>
</ul>