vue2和vue3中v-if和v-for优先级的调整

虽然学不动,但是生命不息,学习还是要继续的。最终还是决定vue3还是要学习起来了。先从官方文档开始,然后就是深入源码了,这都是后话了。

在刷文档时,前面的内容大部分都没变,在读到条件渲染(conditional render)时,我发现有一处跟vue2的不一样,如下图:
在这里插入图片描述
在这里插入图片描述

第一张图是vue3的,第二张图是vue2的,比较一下发现是调整了v-if和v-for的优先级,vue2是v-for优先级高,现在是v-if的优先级高。我读起来很差异的,我还担心是文档写错了呢。自己就用vue3写了一个简单的测试程序,如下:

<!doctype html>
<html>
        <head></head>
        <body>
                <div id="app">
                        <template v-for="item of list" v-if="item.id === 2">
                                <div>{{ item.msg }}</div>
                        </template>
                </div>
                <script src="https://unpkg.com/vue@next"></script>
                <script>
                        const app = Vue.createApp({
                                data() {
                                        return {
                                                list: [
                                                        {id: 1, msg: 'mmmm'},
                                                        {id: 2, msg: 'xxxx'},
                                                        {id: 3, msg: 'eeee'}
                                                ]
                                        };
                                },
                                
                        });
                        app.mount('#app');
                </script>
        </body>
</html>

如果是vue2的话,此时只会显示id为2的一条,但是对于vue3来说就直接报错了,如下:
在这里插入图片描述

看来是真的调整了优先级,因为v-if优先级高了,那么在执行v-if时是没有item的,因此就报错了。因为是刚开始接触vue3,我还不知道它为什么会改动这个,这样对vue2的迁移还是不太友好的,虽然尽量不会把v-if和v-for放在一起使用,但是这个也不能完全保证呀!

-----------------华丽的分割线----------------------------------

中午我又读了list rendering的文档,里面有这样一段话
在这里插入图片描述

继续学习呀:)

如果有帮助,请点赞哈:)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值