vue2和vue3中v-if和v-for优先级的调整
虽然学不动,但是生命不息,学习还是要继续的。最终还是决定vue3还是要学习起来了。先从官方文档开始,然后就是深入源码了,这都是后话了。在刷文档时,前面的内容大部分都没变,在读到条件渲染(conditional render)时,我发现有一处跟vue2的不一样,如下图:第一张图是vue3的,第二张图是vue2的,比较一下发现是调整了v-if和v-for的优先级,vue2是v-for优先级高,现在是v
虽然学不动,但是生命不息,学习还是要继续的。最终还是决定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的文档,里面有这样一段话
继续学习呀:)
如果有帮助,请点赞哈:)
更多推荐
所有评论(0)