原因
因为vue2
中v-for的优先级高于v-if
,如下代码,效果是实现了没错,但是,在v-if工作前,v-for已经将数组user遍历了一遍,若user数组特别庞大,此时对性能的消耗特别大。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<style></style>
</head>
<body>
<div id="app" class="postCover">
<ul>
<li v-for="user in users" v-if="user.isActive" :key="user.id">
{{ user.name }}
</li>
</ul>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<script>
var app = new Vue({
el: '#app',
data: {
users: [
{ id: 1, isActive: 0, name: '隐藏' },
{ id: 2, isActive: 1, name: '显示' },
{ id: 3, isActive: 0, name: '隐藏' },
{ id: 4, isActive: 1, name: '显示' },
{ id: 5, isActive: 0, name: '隐藏' },
{ id: 6, isActive: 1, name: '显示' }
]
}
</script>
</body>
</html>
代码效果
解决办法
先上代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Document</title>
<style></style>
</head>
<body>
<div id="app" class="postCover">
<ul>
//遍历的数组,已经相当于是先将可以显示的元素,过滤为一个数组,此时直接遍历这个数组,就是我们要显示的内容
<li v-for="user in activeUsers" :key="user.id">
{{ user.name }}
</li>
</ul>
</div>
<script src="https://cdn.jsdelivr.net/npm/vue@2/dist/vue.js"></script>
<script>
var app = new Vue({
el: '#app',
data: {
users: [
{ id: 1, isActive: 0, name: '隐藏' },
{ id: 2, isActive: 1, name: '显示' },
{ id: 3, isActive: 0, name: '隐藏' },
{ id: 4, isActive: 1, name: '显示' },
{ id: 5, isActive: 0, name: '隐藏' },
{ id: 6, isActive: 1, name: '显示' }
]
},
computed: {
//用计算属性,过滤出user.isActive为true的元素,并返回这些元素组成的一个数组
activeUsers: function () {
return this.users.filter(function (user) {
return user.isActive
})
}
}
})
</script>
</body>
</html>