v-for 和 v-if的优先级(源码分析)app.$options.render

本文探讨了 Vue 模板中 v-if 和 v-for 语句的优先级问题。当它们在同一元素上使用时,v-for 的优先级高于 v-if,这可能导致性能浪费。为优化性能,建议将 v-if 放到外层的 template 标签中,使条件判断先行,减少不必要的循环。示例代码展示了如何实现这一优化策略。
摘要由CSDN通过智能技术生成
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>

</head>
<body>
<script src="js/Vue.js"></script>
<div id="demo">
    <h1>v-for 和 v-if的优先级</h1>
<!--    <p v-for="child in children" v-if="isFolder">{{child.title}}</p>-->

    <template v-if="isFolder" >
        <p v-for="child in children">{{child.title}}</p>
    </template>
</div>

<script type="text/javascript">
    const app=new Vue({
        el:'#demo',
        data(){
            return{
                children:[
                    {title:'foo'},
                    {title:'bar'}
                ]
            }
        },
        computed:{
            isFolder(){
                return this.children&&this.children.length>0;
            }
        }
    })
    console.log(app.$options.render);

</script>
</body>
</html>

 当v-for与v-if在同一个标签上时,使用app.$options.render打印出渲染的结果。

显示_l(_l为列表执行的函数)的执行在isFolder判断的前边。所以v-for的优先级是大于v-if的,显然这样会浪费了性能

 如果要避免这样的情况,可以使用以下方式,在外层包裹一个<template></template>标签用于v-if的判断,这样条件判断会先执行,而v-for的执行函数_l 则会在判断之后执行。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值