v-if和v-for的优先级,如何处理之间关系

Posted 勇敢*牛牛

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了v-if和v-for的优先级,如何处理之间关系相关的知识,希望对你有一定的参考价值。

v-if和v-for的优先级

一、作用

  • v-if指令用于条件性的渲染一块内容。

这块内容只会在指令的表达式返回true值的时候被渲染

  • v-for指令基于一个数组来渲染一个列表。

v-for=“(值,下标) in 数组” :key="下标(一般有id的就用id没有用下标)"在 v-for 的时候,建议设置key值,并且保证每个key值是独一无二的,这便于diff算法进行优化

两者在用法上

<Modal v-if="isShow" />
<li v-for="(item,index) in arr" :key="index">
     item.label 
</li>

二、优先级

当vue处理指令时,v-for比v-if具有更高的优先级,通过v-if移动到容器元素,不会再重复遍历列表中的每个值,取而代之的是,我们只检查它一次,且不会再v-if为否的时候运行v-for。

但是在vue3中,v-if具有比v-for更高的优先级

三、注意事项

  1. 永远不要把 v-if 和 v-for 同时用在同一个元素上,带来性能方面的浪费(每次渲染都会先循环再进行条件判断)
  2. 如果避免出现这种情况,则在外层嵌套template(页面渲染不生成dom节点),在这一层进行v-if判断,然后在内部进行v-for循环
<template v-if="isShow">
    <p v-for="item in items">
</template>

3.如果条件出现在循环内部,可通过计算属性computed提前过滤掉那些不需要显示的项

computed: 
    items: function() 
      return this.list.filter(function (item) 
        return item.isShow
      )
    

以上是关于v-if和v-for的优先级,如何处理之间关系的主要内容,如果未能解决你的问题,请参考以下文章

如何处理 GatsbyJS 中 markdown 帖子之间的父/子关系

如何处理 REST api 中的关系

v-if和v-for谁的优先级高?如何同时使用?

v-if和v-for的优先级

v-if和v-for的优先级

Vue.js 从源码理解v-for和v-if的优先级的高低