百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

v-if和v-for的优先级是什么?(v-if与v-for)

ztj100 2025-03-13 22:10 29 浏览 0 评论

#一、作用

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

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

v-for 的时候,建议设置key值,并且保证每个key值是独一无二的,这便于diff算法进行优化

两者在用法上



  • {{ item.label }}
  • #二、优先级

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

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

    #示例

    编写一个p标签,同时使用v-ifv-for

    {{ item.title }}

    创建vue实例,存放isShowitems数据

    const app = new Vue({
      el: "#app",
      data() {
        return {
          items: [
            { title: "foo" },
            { title: "baz" }]
        }
      },
      computed: {
        isShow() {
          return this.items && this.items.length > 0
        }
      }
    })
    

    模板指令的代码都会生成在render函数中,通过app.$options.render就能得到渲染函数

    f anonymous() {
      with (this) { return 
        _c('div', { attrs: { "id": "app" } }, 
        _l((items), function (item) 
        { return (isShow) ? _c('p', [_v("\n" + _s(item.title) + "\n")]) : _e() }), 0) }
    }
    

    _lvue的列表渲染函数,函数内部都会进行一次if判断

    初步得到结论:v-for优先级是比v-if

    再将v-forv-if置于不同标签

    再输出下render函数

    f anonymous() {
      with(this){return 
        _c('div',{attrs:{"id":"app"}},
        [(isShow)?[_v("\n"),
        _l((items),function(item){return _c('p',[_v(_s(item.title))])})]:_e()],2)}
    }
    


    这时候我们可以看到,v-forv-if作用在不同标签时候,是先进行判断,再进行列表的渲染

    我们再在查看下vue源码

    源码位置:\vue-dev\src\compiler\codegen\index.js

    export function genElement (el: ASTElement, state: CodegenState): string {
      if (el.parent) {
        el.pre = el.pre || el.parent.pre
      }
      if (el.staticRoot && !el.staticProcessed) {
        return genStatic(el, state)
      } else if (el.once && !el.onceProcessed) {
        return genOnce(el, state)
      } else if (el.for && !el.forProcessed) {
        return genFor(el, state)
      } else if (el.if && !el.ifProcessed) {
        return genIf(el, state)
      } else if (el.tag === 'template' && !el.slotTarget && !state.pre) {
        return genChildren(el, state) || 'void 0'
      } else if (el.tag === 'slot') {
        return genSlot(el, state)
      } else {
        // component or element
        ...
    }
    


    在进行if判断的时候,v-for是比v-if先进行判断

    最终结论:v-for优先级比v-if

    #三、注意事项

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


    1. 如果条件出现在循环内部,可通过计算属性computed提前过滤掉那些不需要显示的项
    computed: {
        items: function() {
          return this.list.filter(function (item) {
            return item.isShow
          })
        }
    }

    相关推荐

    30天学会Python编程:16. Python常用标准库使用教程

    16.1collections模块16.1.1高级数据结构16.1.2示例...

    强烈推荐!Python 这个宝藏库 re 正则匹配

    Python的re模块(RegularExpression正则表达式)提供各种正则表达式的匹配操作。...

    Python爬虫中正则表达式的用法,只讲如何应用,不讲原理

    Python爬虫:正则的用法(非原理)。大家好,这节课给大家讲正则的实际用法,不讲原理,通俗易懂的讲如何用正则抓取内容。·导入re库,这里是需要从html这段字符串中提取出中间的那几个文字。实例一个对...

    Python数据分析实战-正则提取文本的URL网址和邮箱(源码和效果)

    实现功能:Python数据分析实战-利用正则表达式提取文本中的URL网址和邮箱...

    python爬虫教程之爬取当当网 Top 500 本五星好评书籍

    我们使用requests和re来写一个爬虫作为一个爱看书的你(说的跟真的似的)怎么能发现好书呢?所以我们爬取当当网的前500本好五星评书籍怎么样?ok接下来就是学习python的正确姿...

    深入理解re模块:Python中的正则表达式神器解析

    在Python中,"re"是一个强大的模块,用于处理正则表达式(regularexpressions)。正则表达式是一种强大的文本模式匹配工具,用于在字符串中查找、替换或提取特定模式...

    如何使用正则表达式和 Python 匹配不以模式开头的字符串

    需要在Python中使用正则表达式来匹配不以给定模式开头的字符串吗?如果是这样,你可以使用下面的语法来查找所有的字符串,除了那些不以https开始的字符串。r"^(?!https).*&...

    先Mark后用!8分钟读懂 Python 性能优化

    从本文总结了Python开发时,遇到的性能优化问题的定位和解决。概述:性能优化的原则——优化需要优化的部分。性能优化的一般步骤:首先,让你的程序跑起来结果一切正常。然后,运行这个结果正常的代码,看看它...

    Python“三步”即可爬取,毋庸置疑

    声明:本实例仅供学习,切忌遵守robots协议,请不要使用多线程等方式频繁访问网站。#第一步导入模块importreimportrequests#第二步获取你想爬取的网页地址,发送请求,获取网页内...

    简单学Python——re库(正则表达式)2(split、findall、和sub)

    1、split():分割字符串,返回列表语法:re.split('分隔符','目标字符串')例如:importrere.split(',','...

    Lavazza拉瓦萨再度牵手上海大师赛

    阅读此文前,麻烦您点击一下“关注”,方便您进行讨论和分享。Lavazza拉瓦萨再度牵手上海大师赛标题:2024上海大师赛:网球与咖啡的浪漫邂逅在2024年的上海劳力士大师赛上,拉瓦萨咖啡再次成为官...

    ArkUI-X构建Android平台AAR及使用

    本教程主要讲述如何利用ArkUI-XSDK完成AndroidAAR开发,实现基于ArkTS的声明式开发范式在android平台显示。包括:1.跨平台Library工程开发介绍...

    Deepseek写歌详细教程(怎样用deepseek写歌功能)

    以下为结合DeepSeek及相关工具实现AI写歌的详细教程,涵盖作词、作曲、演唱全流程:一、核心流程三步法1.AI生成歌词-打开DeepSeek(网页/APP/API),使用结构化提示词生成歌词:...

    “AI说唱解说影视”走红,“零基础入行”靠谱吗?本报记者实测

    “手里翻找冻鱼,精心的布局;老漠却不言语,脸上带笑意……”《狂飙》剧情被写成歌词,再配上“科目三”背景音乐的演唱,这段1分钟30秒的视频受到了无数网友的点赞。最近一段时间随着AI技术的发展,说唱解说影...

    AI音乐制作神器揭秘!3款工具让你秒变高手

    在音乐创作的领域里,每个人都有一颗想要成为大师的心。但是面对复杂的乐理知识和繁复的制作过程,许多人的热情被一点点消磨。...

    取消回复欢迎 发表评论: