Vue 2 vs Vue 3:v-if 和 v-for 的差异

2024-08-27 17:44

本文主要是介绍Vue 2 vs Vue 3:v-if 和 v-for 的差异,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 Vue 2 和 Vue 3 中,v-if 和 v-for 是用于条件渲染和列表渲染的两个常用指令。虽然两个版本中它们的基本用法一致,但在某些情况下有差异和注意事项。

同时,这也是比较常见的 Vue 面试题之一。

1. 基本用法

1、v-if 用于条件渲染,当条件为 true 时,元素才会被渲染。

<!-- Vue 2 和 Vue 3 中的用法一致 -->
<div v-if="isVisible">This is visible</div>

2、v-for 用于渲染列表,通过迭代数组或对象的每一项生成一组元素。

<!-- Vue 2 和 Vue 3 中的用法一致 -->
<ul><li v-for="item in items" :key="item.id">{{ item.name }}</li>
</ul>

2. v-if 和 v-for 结合

在 Vue 2 和 Vue 3 ,如果在同一个元素上同时使用 v-if 和 v-for,它们的执行顺序是不同的。

- Vue 2,v-for 的优先级高于 v-if,这意味着即使某个列表项不满足 v-if 条件,它也仍然是先被 v-for 迭代,然后才根据 v-if 的条件决定是否渲染。

<!-- Vue 2 中的代码 -->
<template><ul><li v-for="item in items" v-if="item.isVisible" :key="item.id">{{ item.name }}</li></ul>
</template>
<script>
export default {data() {return {items: [{ id: 1, name: 'Item 1', isVisible: true },{ id: 2, name: 'Item 2', isVisible: false },{ id: 3, name: 'Item 3', isVisible: true },]};}
};
</script>

- Vue 3,v-if 的优先级高于 v-for,这意味着在迭代之前,首选会判断是否满足 v-if 的条件,如果条件为 false,则不会执行 v-for。

<!-- Vue 3 中的代码 -->
<template><ul><li v-if="shouldRender" v-for="item in items" :key="item.id">{{ item.name }}</li></ul>
</template>
<script>
export default {data() {return {shouldRender: false, // 控制是否渲染整个列表items: [{ id: 1, name: 'Item 1', isVisible: true },{ id: 2, name: 'Item 2', isVisible: false },{ id: 3, name: 'Item 3', isVisible: true },]};}
};
</script>

Vue 3 认为 Vue 2 设计的优先级有问题,虽然不报错,但是不建议使用。因此在 Vue 3 中,直接设计 v-if 的优先级高于 v-for。(先执行 v-if,然后执行 v-for)

3. 改进

在 Vue 3 中,官方建议,避免在同一个元素上同时使用 v-if 和 v-for,而是将它们分开处理。不仅可以提升代码的可读性,还能避免潜在的逻辑错误。

1、Vue 2 使用计算属性分离逻辑

Vue 2 中,v-for 的优先级高于 v-if,导致每一次循环时判断,修改数据之后,也要重新循环所有项,会大大耗损效率。

<template><ul><!-- 只使用 v-for,因为计算属性已经过滤了不可见的项 --><li v-for="item in visibleItems" :key="item.id">{{ item.name }}</li></ul>
</template>
<script>
export default {data() {return {items: [{ id: 1, name: 'Item 1', isVisible: true },{ id: 2, name: 'Item 2', isVisible: false },{ id: 3, name: 'Item 3', isVisible: true },]};},computed: {// 计算属性:只返回 isVisible 为 true 的项visibleItems() {return this.items.filter(item => item.isVisible);}}
};
</script>

2、Vue 3 分离逻辑到外部容器

<template><!-- 将 v-if 移动到外部容器 --><div v-if="shouldRender"><ul><li v-for="item in items" :key="item.id">{{ item.name }}</li></ul></div>
</template><script>
export default {data() {return {shouldRender: false, // 控制是否渲染整个列表items: [{ id: 1, name: 'Item 1', isVisible: true },{ id: 2, name: 'Item 2', isVisible: false },{ id: 3, name: 'Item 3', isVisible: true },]};}
};
</script>

4. 注意点

4.1 v-for 的 key

在 Vue 中,key 属性是 Vue 用于标识和追踪每个列表项的唯一标识符,用于在渲染列表时帮助 Vue 追踪每个元素的身份(确定哪些元素被改变、添加或移除),从而在更新DOM 时优化性能。

也就是,在数据变化时,Vue 能够精确地找到被改变的元素,并且只更新这些元素,避免了整个列表的重新渲染。

<!-- 假设 items 是一个数组,每个 item 都有唯一的 id -->
<div v-for="item in items" :key="item.id">{{ item.name }}
</div>
4.2 面试题:为什么不推荐使用索引作为 key

1、列表项顺序变化:当顺序发生变化时,使用索引作为 key 可能导致渲染错误。Vue 使用 key 识别哪个元素是新的,哪个是旧的,以便在 DOM 中高效的更新。如果使用索引,当列表项顺序变化时,Vue 可能无法正确地识别出元素的移动,而可能会错误地删除或重新创建元素。

2、动态添加或删除列表项:当列表项被动态添加或删除时,使用索引也可能导致问题。例如,如果从列表中删除一个元素,所有后续元素的索引都会改变,这可能会导致 Vue 错误地重新渲染整个列表。

3、性能问题:Vue 使用 key 以便最小化 DOM 操作,更新那些真正改变的 DOM 元素。如果 key 不唯一或者不稳定,Vue 可能需要执行更多的 DOM 操作来更新列表,导致性能降低。

4、组件复用问题:如果列表项是一个 Vue 组件,Vue 会尝试重用具有相同 key 值的组件实例,如果 key 不稳定,可能导致组件状态的错误或丢失。

5、可预测性:使用一个稳定的、可预测的 key 可以提高 Vue 的更新算法的效率。每个节点的 key 唯一,以便 Vue 可以准确跟踪,从而重用和重新排序现有的元素,而不是重新创建它们。

因此推荐使用数据项的唯一标识符(如 ID)作为 key,这样可以确保在数据变化时,Vue 能够准确追踪和更新 DOM 元素。

<div v-for="item in items" :key="item.id">{{ item.name }}
</div>

这篇关于Vue 2 vs Vue 3:v-if 和 v-for 的差异的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1112345

相关文章

CSS弹性布局常用设置方式

《CSS弹性布局常用设置方式》文章总结了CSS布局与样式的常用属性和技巧,包括视口单位、弹性盒子布局、浮动元素、背景和边框样式、文本和阴影效果、溢出隐藏、定位以及背景渐变等,通过这些技巧,可以实现复杂... 一、单位元素vm 1vm 为视口的1%vh 视口高的1%vmin 参照长边vmax 参照长边re

使用Navicat工具比对两个数据库所有表结构的差异案例详解

《使用Navicat工具比对两个数据库所有表结构的差异案例详解》:本文主要介绍如何使用Navicat工具对比两个数据库test_old和test_new,并生成相应的DDLSQL语句,以便将te... 目录概要案例一、如图两个数据库test_old和test_new进行比较:二、开始比较总结概要公司存在多

CSS3中使用flex和grid实现等高元素布局的示例代码

《CSS3中使用flex和grid实现等高元素布局的示例代码》:本文主要介绍了使用CSS3中的Flexbox和Grid布局实现等高元素布局的方法,通过简单的两列实现、每行放置3列以及全部代码的展示,展示了这两种布局方式的实现细节和效果,详细内容请阅读本文,希望能对你有所帮助... 过往的实现方法是使用浮动加

css渐变色背景|<gradient示例详解

《css渐变色背景|<gradient示例详解》CSS渐变是一种从一种颜色平滑过渡到另一种颜色的效果,可以作为元素的背景,它包括线性渐变、径向渐变和锥形渐变,本文介绍css渐变色背景|<gradien... 使用渐变色作为背景可以直接将渐China编程变色用作元素的背景,可以看做是一种特殊的背景图片。(是作为背

CSS自定义浏览器滚动条样式完整代码

《CSS自定义浏览器滚动条样式完整代码》:本文主要介绍了如何使用CSS自定义浏览器滚动条的样式,包括隐藏滚动条的角落、设置滚动条的基本样式、轨道样式和滑块样式,并提供了完整的CSS代码示例,通过这些技巧,你可以为你的网站添加个性化的滚动条样式,从而提升用户体验,详细内容请阅读本文,希望能对你有所帮助...

css实现图片旋转功能

《css实现图片旋转功能》:本文主要介绍了四种CSS变换效果:图片旋转90度、水平翻转、垂直翻转,并附带了相应的代码示例,详细内容请阅读本文,希望能对你有所帮助... 一 css实现图片旋转90度.icon{ -moz-transform:rotate(-90deg); -webkit-transfo

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三