这篇文章主要介绍了Vue中为什么要避免同时使用v-for和 v-if,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
v-for 遍历避免同时使用 v-if
为什么要避免同时使用 v-for 和 v-if
在 Vue2 中 v-for 优先级更高,所以编译过程中会把列表元素全部遍历生成虚拟 DOM,再来通过 v-if 判断符合条件的才渲染,就会造成性能的浪费,因为我们希望的是不符合条件的虚拟 DOM都不要生成
在 Vue3 中 v-if 的优先级更高,就意味着当判断条件是 v-for 遍历的列表中的属性的话,v-if 是拿不到的
所以在一些需要同时用到的场景,就可以通过计算属性来过滤一下列表,如下
<template> <ul> <li v-for="item in activeList" :key="item.id"> {{ item.title }} </li> </ul></template><script>// Vue2.xexport default { computed: { activeList() { return this.list.filter( item => { return item.isActive }) } }}// Vue3import { computed } from "vue";const activeList = computed(() => { return list.filter( item => { return item.isActive})})</script>
感谢你能够认真阅读完这篇文章,希望小编分享的“Vue中为什么要避免同时使用v-for和 v-if”这篇文章对大家有帮助,同时也希望大家多多支持编程网,关注编程网行业资讯频道,更多相关知识等着你来学习!