vue 限制渲染条数_深入理解Vue 的条件渲染和列表渲染
這兩天學習了Vue.js 感覺條件渲染和列表渲染知識點挺多的,而且很重要,所以,今天添加一點小筆記。
條件渲染
v-if
在 < template > 中配合 v-if 渲染一整組
在使用 v-if 控制元素的時候,我們需要將它添加到這個元素上去。然而如果要切換很多元素的時候,一個個的添加就太麻煩了。這時候就可以使用 < template > 將一組元素進行包裹,并在上面使用 v-if。最終的渲染結果不會包含 < template > 元素。
Title
Paragraph 1
Paragraph 2
data:{
ok:true
}
我們更改 ok 的值,就可以控制整組的元素了
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 塊”。可以鏈式地使用多次:
優秀
及格
不及格
類似于 v-else,v-else-if 必須緊跟在 v-if 或者 v-else-if 元素之后。
可復用元素
Vue 會盡可能高效地渲染元素,通常會復用已有元素而不是從頭開始渲染。這么做,除了使 Vue 變得非常快之外,還有一些有用的好處。例如,如果你允許用戶在不同的登錄方式之間切換:
Username
var exp=new Vue({
el:".exp",
data:{
loginType:"username"
},
methods:{
btn:function(){
if(this.loginType==="username"){
this.loginType="email"
}else{
this.loginType="username"
}
}
}
})
那么在上面的代碼中切換 loginType 將不會清除用戶已經輸入的內容。因為兩個模板使用了相同的元素,< input > 不會被替換掉——僅僅是替換了它的 placeholder。
復制上面的代碼,在自己的瀏覽器中試一試。
有時候我們不希望瀏覽器保留我們輸入的內容,所以 Vue 為你提供了一種方式來聲明“這兩個元素是完全獨立的——不要復用它們”。只需添加一個具有唯一值的 key 屬性即可:
Username
v-show
另一個用于根據條件展示元素的選項是 v-show 指令。用法大致一樣:
Hello!
data:{
ok:false
}
不同的是帶有 v-show 的元素始終會被渲染并保留在 DOM 中。v-show 是簡單地切換元素的 CSS 屬性 display 。
渲染如下
列表渲染
使用 v-for 把一個數組對應為一組元素
我們用 v-for 指令根據一組數組的選項列表進行渲染。 v-for 指令需要以 item in items 形式的特殊語法, items 是源數據數組并且 item 是數組元素迭代的別名。
- {{item.text}}
data:{
items:[
{text:"eat"},
{text:"play"},
{text:"game"}
]
}
渲染結果
- eat
- play
- game
v-for 還支持一個可選的第二個參數為當前項的索引。
- {{index}}-{{item.text}}
var exp=new Vue({
el:".exp",
data:{
items:[
{text:'eat'},
{text:'paly'},
{text:'game'}
]
}
})
結果
0-eat
1-paly
2-game
一個對象的 v-for
你也可以用 v-for 通過一個對象的屬性來迭代。
- {{value}}
var exp=new Vue({
el:".exp",
data:{
obj:{
firstname:"PureView",
lastname:"一個安靜的美男子",
age:18
}
}
})
結果
PureView
一個安靜的美男子
18
你一共可以提供三個參數,第二個參數為鍵名,第三個為索引:
{{index+1}}. {{key}}: {{value}}結果
1. firstname: PureView
2. lastname: 一個安靜的美男子
3. age: 18
數組更新檢測
變異方法
Vue 包含一組觀察數組的變異方法,所以它們也將會觸發視圖更新。這些方法如下:
push()
pop()
shift()
unshift()
splice()
sort()
reverse()
例如
- {{item.text}}
var exp=new Vue({
el:".exp",
data:{
items:[
{text:"eat"},
{text:"play"},
{text:"game"}
]
}
})
exp.items.push({text:'watch TV'})
重塑數組
變異方法(mutation method),顧名思義,會改變被這些方法調用的原始數組。相比之下,也有非變異(non-mutating method)方法,例如: filter(), concat() 和 slice() 。這些不會改變原始數組,但總是返回一個新數組。當使用非變異方法時,可以用新數組替換舊數組:
data:{
items:[
{text:"eat"},
{text:"play"},
{text:"game"},
{text:"gaming"},
{text:"wot"},
{text:"wows"},
{text:"wt"}
]
}
}
exp.items.slice(0,5)
利用上一節的例子,返回的值不會改變原數據,在控制臺打印我們就能看到了。
注意事項
由于 JavaScript 的限制, Vue 不能檢測以下變動的數組:
當你利用索引直接設置一個項時,例如: vm.items[indexOfItem] = newValue
當你修改數組的長度時,例如: vm.items.length = newLength
為了解決第一類問題,以下兩種方式都可以實現和 vm.items[indexOfItem] = newValue 相同的效果, 同時也將觸發狀態更新:
// Vue.set
Vue.set(exp.items, indexOfItem, newValue)
// Array.prototype.splice
exp.items.splice(indexOfItem, 1, newValue)
為了解決第二類問題,你可以使用 splice:
exp.items.splice(newLength)
對象更新檢測
由于現代JavaScript的限制,Vue無法檢測屬性添加或刪除。 例如:
var exp=new Vue({
data:{
a:1
}
})
vm.b=2 //模板內無響應
Vue是不允許動態地向已創建的實例添加新的根級屬性的。這時候 Vue 提供了一個方法用來對對象添加屬性:
Vue.set(object,key,value)
舉個例子
var exp=new Vue({
el:".exp",
data:{
obj:{
me:"pureview",
pet1:"dog",
pet2:"cat",
hobby:"games"
}
}
})
我們在控制臺輸入下面的代碼,就可以看到模板內的數據進行了更新
Vue.set(exp.obj,"todo","eating")
除了添加屬性,我們也可以進行刪除操作
Vue.delete(exp.obj,"pet2")
顯示過濾/排序結果
有時,我們想要顯示一個數組的過濾或排序副本,而不實際改變或重置原始數據。在這種情況下,可以創建返回過濾或排序數組的計算屬性。
比如我們在一個數組中取其偶數
- {{n}}
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
})
}
}
})
模板顯示結果:
2
4
6
8
10
在計算屬性不適用的情況下 (例如,在嵌套 v-for 循環中) 你可以使用一個 method 方法:
- {{n}}
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
})
}
}
})
結果是一樣的
一段取值范圍的 v-for
v-for 也可以取整數。在這種情況下,它將重復多次模板。
{{ n }}
結果
1 2 3 4 5 6 7 8 9 10
v-for 在 < template > 上
與模板v-if類似,您還可以使用帶有 v-for 的< template >標簽來呈現多個元素的塊。
- {{ item.msg }}
v-for 和 v-if
當 v-for 與 v-if 一起使用時,v-for 具有比 v-if 更高的優先級,這意味著 v-if 將分別重復運行于每個 v-for 循環中。當我們僅為某些項目渲染節點時,這可能很有用:
{{ todo }}
而如果我們的目的是有條件地跳過循環的執行,那么可以將 v-if 置于外層元素 (或 < template >)上。如:
{{ todo }}
No todos left!
組件的 v-for
在 Vue 的 2.2.0 以上的版本中,我們要在組件中使用 v-for 時,不許使用 key
雖然在自定義組件里可以使用 v-for ,但是,他不能自動傳遞數據到組件里,因為組件有自己獨立的作用域。為了傳遞迭代數據到組件里,我們要用 props :
Vue.component('mycom', {
template: "
{{this.lie}}
",props:["lie"]
})
var exp=new Vue({
el:".exp",
data:{
items:[
{text:'從前有座山'},
{text:'山上有座廟'},
{text:'廟里有個老和尚'},
{text:'正在玩王者榮耀'}
]
}
})
結果
從前有座山
山上有座廟
廟里有個老和尚
正在玩王者榮耀
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
總結
以上是生活随笔為你收集整理的vue 限制渲染条数_深入理解Vue 的条件渲染和列表渲染的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python创建一个json_如何为Py
- 下一篇: html怎样在一张图片里写字,用HTML