中配合 v-if 渲染一整組 ..."/>
您好,登錄后才能下訂單哦!
這兩天學(xué)習(xí)了Vue.js 感覺條件渲染和列表渲染知識(shí)點(diǎn)挺多的,而且很重要,所以,今天添加一點(diǎn)小筆記。
條件渲染
v-if
在 < template > 中配合 v-if 渲染一整組
在使用 v-if 控制元素的時(shí)候,我們需要將它添加到這個(gè)元素上去。然而如果要切換很多元素的時(shí)候,一個(gè)個(gè)的添加就太麻煩了。這時(shí)候就可以使用 < template > 將一組元素進(jìn)行包裹,并在上面使用 v-if。最終的渲染結(jié)果不會(huì)包含 < template > 元素。
<template v-if="ok"> <h2>Title</h2> <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 元素的后面——否則它將不會(huì)被識(shí)別。
v-else-if
v-else-if,顧名思義,充當(dāng) v-if 的“else-if 塊”??梢枣?zhǔn)降厥褂枚啻危?/p>
<div> <p v-if="sc>=90">優(yōu)秀</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 元素之后。
可復(fù)用元素
Vue 會(huì)盡可能高效地渲染元素,通常會(huì)復(fù)用已有元素而不是從頭開始渲染。這么做,除了使 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> <script> var exp=new Vue({ el:".exp", data:{ loginType:"username" }, methods:{ btn:function(){ if(this.loginType==="username"){ this.loginType="email" }else{ this.loginType="username" } } } }) </script>
那么在上面的代碼中切換 loginType 將不會(huì)清除用戶已經(jīng)輸入的內(nèi)容。因?yàn)閮蓚€(gè)模板使用了相同的元素,< input > 不會(huì)被替換掉——僅僅是替換了它的 placeholder。
復(fù)制上面的代碼,在自己的瀏覽器中試一試。
有時(shí)候我們不希望瀏覽器保留我們輸入的內(nèi)容,所以 Vue 為你提供了一種方式來聲明“這兩個(gè)元素是完全獨(dú)立的——不要復(fù)用它們”。只需添加一個(gè)具有唯一值的 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
另一個(gè)用于根據(jù)條件展示元素的選項(xiàng)是 v-show 指令。用法大致一樣:
<h2 v-show="ok">Hello!</h2> <script> data:{ ok:false } </script>
不同的是帶有 v-show 的元素始終會(huì)被渲染并保留在 DOM 中。v-show 是簡單地切換元素的 CSS 屬性 display 。
渲染如下
<div ></div>
列表渲染
使用 v-for 把一個(gè)數(shù)組對(duì)應(yīng)為一組元素
我們用 v-for 指令根據(jù)一組數(shù)組的選項(xiàng)列表進(jìn)行渲染。 v-for 指令需要以 item in items 形式的特殊語法, items 是源數(shù)據(jù)數(shù)組并且 item 是數(shù)組元素迭代的別名。
<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>
渲染結(jié)果
<div class="exp"> <ul> <li>eat</li> <li>play</li> <li>game</li> </ul> </div>
v-for 還支持一個(gè)可選的第二個(gè)參數(shù)為當(dāng)前項(xiàng)的索引。
<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>
結(jié)果
0-eat
1-paly
2-game
一個(gè)對(duì)象的 v-for
你也可以用 v-for 通過一個(gè)對(duì)象的屬性來迭代。
<div class="exp"> <ul> <li v-for="value in obj">{{value}}</li> </ul> </div> <script> var exp=new Vue({ el:".exp", data:{ obj:{ firstname:"PureView", lastname:"一個(gè)安靜的美男子", age:18 } } }) </script>
結(jié)果
PureView
一個(gè)安靜的美男子
18
你一共可以提供三個(gè)參數(shù),第二個(gè)參數(shù)為鍵名,第三個(gè)為索引:
<li v-for="value,key,index in obj">{{index+1}}. {{key}}: {{value}}</li>
結(jié)果
1. firstname: PureView
2. lastname: 一個(gè)安靜的美男子
3. age: 18
數(shù)組更新檢測
變異方法
Vue 包含一組觀察數(shù)組的變異方法,所以它們也將會(huì)觸發(fā)視圖更新。這些方法如下:
例如
<div class="exp"> <ul> <li v-for="item in items">{{item.text}}</li> </ul> </div> <script> var exp=new Vue({ el:".exp", data:{ items:[ {text:"eat"}, {text:"play"}, {text:"game"} ] } }) exp.items.push({text:'watch TV'}) </script>
重塑數(shù)組
變異方法(mutation method),顧名思義,會(huì)改變被這些方法調(diào)用的原始數(shù)組。相比之下,也有非變異(non-mutating method)方法,例如: filter(), concat() 和 slice() 。這些不會(huì)改變?cè)紨?shù)組,但總是返回一個(gè)新數(shù)組。當(dāng)使用非變異方法時(shí),可以用新數(shù)組替換舊數(shù)組:
data:{ items:[ {text:"eat"}, {text:"play"}, {text:"game"}, {text:"gaming"}, {text:"wot"}, {text:"wows"}, {text:"wt"} ] } } exp.items.slice(0,5)
利用上一節(jié)的例子,返回的值不會(huì)改變?cè)瓟?shù)據(jù),在控制臺(tái)打印我們就能看到了。
注意事項(xiàng)
由于 JavaScript 的限制, Vue 不能檢測以下變動(dòng)的數(shù)組:
為了解決第一類問題,以下兩種方式都可以實(shí)現(xiàn)和 vm.items[indexOfItem] = newValue 相同的效果, 同時(shí)也將觸發(fā)狀態(tài)更新:
// Vue.set Vue.set(exp.items, indexOfItem, newValue)
// Array.prototype.splice exp.items.splice(indexOfItem, 1, newValue)
為了解決第二類問題,你可以使用 splice:
exp.items.splice(newLength)
對(duì)象更新檢測
由于現(xiàn)代JavaScript的限制,Vue無法檢測屬性添加或刪除。 例如:
var exp=new Vue({ data:{ a:1 } }) vm.b=2 //模板內(nèi)無響應(yīng)
Vue是不允許動(dòng)態(tài)地向已創(chuàng)建的實(shí)例添加新的根級(jí)屬性的。這時(shí)候 Vue 提供了一個(gè)方法用來對(duì)對(duì)象添加屬性:
Vue.set(object,key,value)
舉個(gè)例子
var exp=new Vue({ el:".exp", data:{ obj:{ me:"pureview", pet1:"dog", pet2:"cat", hobby:"games" } } })
我們?cè)诳刂婆_(tái)輸入下面的代碼,就可以看到模板內(nèi)的數(shù)據(jù)進(jìn)行了更新
Vue.set(exp.obj,"todo","eating")
除了添加屬性,我們也可以進(jìn)行刪除操作
Vue.delete(exp.obj,"pet2")
顯示過濾/排序結(jié)果
有時(shí),我們想要顯示一個(gè)數(shù)組的過濾或排序副本,而不實(shí)際改變或重置原始數(shù)據(jù)。在這種情況下,可以創(chuàng)建返回過濾或排序數(shù)組的計(jì)算屬性。
比如我們?cè)谝粋€(gè)數(shù)組中取其偶數(shù)
<div class="exp"> <ul> <li v-for="n in numbers">{{n}}</li> </ul> </div> <script> var exp=new Vue({ el:".exp", data:{ num:[1,2,3,4,5,6,7,8,9,10] }, computed:{ numbers:function(){ return this.num.filter(function(num){ return num%2===0 }) } } }) </script>
模板顯示結(jié)果:
2
4
6
8
10
在計(jì)算屬性不適用的情況下 (例如,在嵌套 v-for 循環(huán)中) 你可以使用一個(gè) method 方法:
<div class="exp"> <ul> <li v-for="n in even(num)">{{n}}</li> </ul> </div> <script> var exp=new Vue({ el:".exp", data:{ num:[1,2,3,4,5,6,7,8,9,10] }, methods:{ even:function(num){ return num.filter(function(num){ return num%2===0 }) } } }) </script>
結(jié)果是一樣的
一段取值范圍的 v-for
v-for 也可以取整數(shù)。在這種情況下,它將重復(fù)多次模板。
<div> <span v-for="n in 10">{{ n }} </span> </div>
結(jié)果
1 2 3 4 5 6 7 8 9 10
v-for 在 < template > 上
與模板v-if類似,您還可以使用帶有 v-for 的< template >標(biāo)簽來呈現(xiàn)多個(gè)元素的塊。
<ul> <template v-for="item in items"> <li>{{ item.msg }}</li> <li class="divider"></li> </template> </ul>
v-for 和 v-if
當(dāng) v-for 與 v-if 一起使用時(shí),v-for 具有比 v-if 更高的優(yōu)先級(jí),這意味著 v-if 將分別重復(fù)運(yùn)行于每個(gè) v-for 循環(huán)中。當(dāng)我們僅為某些項(xiàng)目渲染節(jié)點(diǎn)時(shí),這可能很有用:
<li v-for="todo in todos" v-if="!todo.isComplete"> {{ todo }} </li>
而如果我們的目的是有條件地跳過循環(huán)的執(zhí)行,那么可以將 v-if 置于外層元素 (或 < template >)上。如:
<ul v-if="todos.length"> <li v-for="todo in todos"> {{ todo }} </li> </ul> <p v-else>No todos left!</p>
組件的 v-for
在 Vue 的 2.2.0 以上的版本中,我們要在組件中使用 v-for 時(shí),不許使用 key
雖然在自定義組件里可以使用 v-for ,但是,他不能自動(dòng)傳遞數(shù)據(jù)到組件里,因?yàn)榻M件有自己獨(dú)立的作用域。為了傳遞迭代數(shù)據(jù)到組件里,我們要用 props :
<my-component v-for="(item,index) in items" v-bind:key="index" :lie="item.text"l></my-component> <script> Vue.component('mycom', { template: "<p>{{this.lie}}</p>", props:["lie"] }) var exp=new Vue({ el:".exp", data:{ items:[ {text:'從前有座山'}, {text:'山上有座廟'}, {text:'廟里有個(gè)老和尚'}, {text:'正在玩王者榮耀'} ] } }) </script>
結(jié)果
從前有座山
山上有座廟
廟里有個(gè)老和尚
正在玩王者榮耀
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。