v-if

用于条件性的渲染一块内容。这块内容只会在指令的表达式返回 true值的时候被渲染。

1
2
// isShow = true
<p v-if="isShow"><p/>

v-for

基于一个数组来渲染列表。v-for 指令需要使用 item in items 形式的特殊语法,其中 items 是源数据数组或者对象,而 item 则是被迭代的数组元素的别名。

1
2
3
<li v-for="item in items" :key="item.id">
{{ item.label }}
</li>

使用技巧

问题

v-ifv-for都是vue模板系统中的指令。

vue模板编译的时候,会将指令系统转化成可执行的render函数。

v-forv-if在同一个标签的的时候,渲染的时候会先进行列表渲染再进行if判断。这样就造成了性能浪费,本身不需要渲染的内容会在渲染后再销毁。

解决方案
  1. 永远不要把 v-ifv-for 同时用在同一个元素上,带来性能方面的浪费(每次渲染都会先循环再进行条件判断)

  2. 如果避免出现这种情况,则在外层嵌套template(页面渲染不生成dom节点),在这一层进行v-if判断,然后在内部进行v-for循环

    1
    2
    3
    <template v-if="isShow">
    <p v-for="item in items">
    </template>
  3. 如果条件出现在循环内部,可通过计算属性computed提前过滤掉那些不需要显示的项

    1
    2
    3
    4
    5
    6
    7
    computed: {
    items: function() {
    return this.list.filter(function (item) {
    return item.isShow
    })
    }
    }