Vue中的v-if和v-for的使用技巧
v-if
用于条件性的渲染一块内容。这块内容只会在指令的表达式返回 true值的时候被渲染。
1 | // isShow = true |
v-for
基于一个数组来渲染列表。v-for 指令需要使用 item in items 形式的特殊语法,其中 items 是源数据数组或者对象,而 item 则是被迭代的数组元素的别名。
1 | <li v-for="item in items" :key="item.id"> |
使用技巧
问题
v-if与v-for都是vue模板系统中的指令。
在vue模板编译的时候,会将指令系统转化成可执行的render函数。
v-for和v-if在同一个标签的的时候,渲染的时候会先进行列表渲染再进行if判断。这样就造成了性能浪费,本身不需要渲染的内容会在渲染后再销毁。
解决方案
永远不要把
v-if和v-for同时用在同一个元素上,带来性能方面的浪费(每次渲染都会先循环再进行条件判断)如果避免出现这种情况,则在外层嵌套
template(页面渲染不生成dom节点),在这一层进行v-if判断,然后在内部进行v-for循环1
2
3<template v-if="isShow">
<p v-for="item in items">
</template>如果条件出现在循环内部,可通过计算属性
computed提前过滤掉那些不需要显示的项1
2
3
4
5
6
7computed: {
items: function() {
return this.list.filter(function (item) {
return item.isShow
})
}
}
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 wn244的个人博客!
