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

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

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

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



        
        
                

如果是vue2的话,此时只会显示id为2的一条,但是对于vue3来说就直接报错了,如下:
vue2和vue3中v-if和v-for优先级的调整_第1张图片

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

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

中午我又读了list rendering的文档,里面有这样一段话
vue2和vue3中v-if和v-for优先级的调整_第2张图片

继续学习呀:)

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

你可能感兴趣的:(前端之路)