Vue3中v-if和v-for優(yōu)先級實例詳解
在vue2中應盡量避免二者同時使用
當
v-if與v-for一起使用時,v-for具有比v-if更高的優(yōu)先級。
那么,我們舉個例子說明為啥不推薦
<template>
<div class="hello">
<div v-for="(item,index) in list" v-if="index === 9" :key="item" ></div>
</div>
</template>
?
<script>
export default {
data(){
return {
list:[1,2,3,4,5,6,7,8,9,10] //需要遍歷的數據
}
}
};
</script>
?
<style scoped>
</style>它實際經過的運算是這樣的
this.list.map(function (item,index) {
if (index===9) {
return item
}
})因此哪怕我們只渲染出一小部分的元素,也得在每次重渲染的時候遍歷整個列表,不論是否發(fā)生了變化。
不建議這樣做的原因就是比較浪費性能
Vue2 推薦的改進方案也是比較簡單,就是采用計算屬性去生成你要遍歷的數組
如下
<template>
<div class="hello">
<!-- 2. 然后這里去循環(huán)已經被過濾的屬性 -->
<div v-for="(item) in ListArr" :key="item" ></div>
</div>
</template>
?
<script>
export default {
data(){
return {
list:[1,2,3,4,5,6,7,8,9,10]
}
},
computed:{
//1. 在computed里先做好判斷,這里過濾的成本遠比v-if的成本低
ListArr(){
return this.list.filter((_,index) => index === 1)
}
}
};
</script>
<style scoped>
</style>從計算成本上來說,在計算屬性中過濾會比在dom中判斷是否顯示更低。
vue3中的改變
當
v-if與v-for一起使用時,v-if具有比v-for更高的優(yōu)先級。
那么是不是就可以鼓勵大家這樣使用呢?很顯然不是,官方文檔仍然不推薦同時使用,我們看下為什么
同樣的,我們仍然使用上面例子做分析
<template>
<div class="hello">
<div v-for="(item,index) in list" v-if="index === 9" :key="item" ></div>
</div>
</template>
?
<script>
export default {
data(){
return {
list:[1,2,3,4,5,6,7,8,9,10] //需要遍歷的數據
}
}
};
</script>
<style scoped>
</style>由于 v-if 優(yōu)先級高,導致頁面什么也不會渲染,控制臺還有報錯
[Vue warn]: Property "index" was accessed during render but is not defined on instance.
當然還有一些其它用法例如這種,可以顯示數據,只是會一些Vue warn的警告
<template>
<div class="hello">
<ul>
<li v-for="(item, index) in list" :key="index" v-if="item.show">
{{ item.name }}
</li>
</ul>
</div>
</template>
?
<script>
export default {
data(){
return {
list:[
{ name: '張三', show: false },
{ name: '李四', show: true },
] //需要遍歷的數據
}
}
};
</script>
<style scoped>
</style>這種方法也不是最好的,官方推薦的寫法是這樣的, 把 v-for 移動到容器元素上,例如ul,ol 或者外面包裹一層 template
<template>
<div class="hello">
<ul>
<template v-for="(item, index) in list" :key="index">
<li v-if="item.show">
{{ item.name }}
</li>
</template>
</ul>
</div>
</template>
?
<script>
export default {
data(){
return {
list:[
{ name: '張三', show: false },
{ name: '李四', show: true },
] //需要遍歷的數據
}
}
};
</script>
<style scoped>
</style>但如果想要有條件地跳過循環(huán)的執(zhí)行,那么可以將v-if置于外層元素或者template上。
例如這樣
<template>
<div class="hello">
<ul v-if="list.length">
<li v-for="(item, index) in list" :key="index">
{{ item.name }}
</li>
</ul>
</div>
</template>
?
<script>
export default {
data(){
return {
list:[
{ name: '張三', show: false },
{ name: '李四', show: true },
] //需要遍歷的數據
}
}
};
</script>
<style scoped>
</style>結論
- 在vue2中,v-for的優(yōu)先級高于v-if
- 在vue3中,v-if的優(yōu)先級高于v-for
- 兩種混在一起寫法均不被官方推薦
補充:注意事項
1.永遠不要把 v-if 和 v-for 同時用在同一個元素上,帶來性能方面的浪費(每次渲染都會先循環(huán)再進行條件判斷)
2.如果避免出現這種情況,則在外層嵌套template(頁面渲染不生成dom節(jié)點),在這一層進行v-if判斷,然后在內部進行v-for循環(huán)
<template v-if="isShow">
<p v-for="item in items">
</template>
3.如果條件出現在循環(huán)內部,可通過計算屬性computed提前過濾掉那些不需要顯示的項
computed: {
items: function() {
return this.list.filter(function (item) {
return item.isShow
})
}
}
總結
到此這篇關于Vue3中v-if和v-for優(yōu)先級詳解的文章就介紹到這了,更多相關Vue3 v-if和v-for優(yōu)先級內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue2移動端使用vue-qrcode-reader實現掃一掃功能的步驟
最近在使用vue開發(fā)的h5移動端想要實現一個調用攝像頭掃描二維碼的功能,所以下面這篇文章主要給大家介紹了關于vue2移動端使用vue-qrcode-reader實現掃一掃功能的相關資料,需要的朋友可以參考下2023-06-06

