目录
- vue2
- vue3
官方文档上说不推荐将v-for与v-if在同一个标签上使用,因为两者优先级并不明显。
那么到底是那个指令的优先级比较高呢? 在vue2与vue3中答案是相反的
。
vue2
在vue2中将2个指令放在同一个标签上
<template>
<ul>
<li v-for="item in list" :key="item.key" v-if="item.key!=2">{{ item.name }}</li>
</ul>
</template>
<script>
export default {
name: 'App',
data(){
return{
list:[
{
key: '1',
name: 'item1'
},
{
key: '2',
name: 'item2'
},
{
key: '3',
name: 'item3'
}
]
}
}
}
</script>
eslint会提示不建议将两个指令放在同一个标签上
The 'list' variable inside 'v-for' directive should be replaced with a computed property that returns filtered array instead. You should not mix 'v-for' with 'v-if'
其实是因为在vue2中v-for比v-if的优先级高
,当v-for与v-if在同一个标签上时,会先循环然后再进行if判断造成性能浪费。
vue3
在vue3中将2个指令放在同一个标签上:
<template>
<ul>
<li v-for="item in list" :key="item.key" v-if="item.key!=2">{{ item.name }}</li>
</ul>
</template>
<script>
export default{
setup(){
const list = [
{
key: '1',
name: 'item1'
},
{
key: '2',
name: 'item2'
},
{
key: '3',
name: 'item3'
}
]
return{
list
}
}
}
</script>
报错:Cannot read properties of undefined (reading ‘key’)
原因:在vue3中 v-if的优先级高于v-for
,v-if 的条件将无法访问到 v-for 作用域内定义的变量别名。
相当于先执行v-if=‘item.key != 2’ 此时还没有执行v-for指令,item相当于为undefiend,通过点语法访问undefined的属性值自然就会报错啦。