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

相关文章

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本

HTML5 搜索框Search Box详解

《HTML5搜索框SearchBox详解》HTML5的搜索框是一个强大的工具,能够有效提升用户体验,通过结合自动补全功能和适当的样式,可以创建出既美观又实用的搜索界面,这篇文章给大家介绍HTML5... html5 搜索框(Search Box)详解搜索框是一个用于输入查询内容的控件,通常用于网站或应用程

CSS3中的字体及相关属性详解

《CSS3中的字体及相关属性详解》:本文主要介绍了CSS3中的字体及相关属性,详细内容请阅读本文,希望能对你有所帮助... 字体网页字体的三个来源:用户机器上安装的字体,放心使用。保存在第三方网站上的字体,例如Typekit和Google,可以link标签链接到你的页面上。保存在你自己Web服务器上的字

html 滚动条滚动过快会留下边框线的解决方案

《html滚动条滚动过快会留下边框线的解决方案》:本文主要介绍了html滚动条滚动过快会留下边框线的解决方案,解决方法很简单,详细内容请阅读本文,希望能对你有所帮助... 滚动条滚动过快时,会留下边框线但其实大部分时候是这样的,没有多出边框线的滚动条滚动过快时留下边框线的问题通常与滚动条样式和滚动行

使用vscode搭建pywebview集成vue项目实践

《使用vscode搭建pywebview集成vue项目实践》:本文主要介绍使用vscode搭建pywebview集成vue项目实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录环境准备项目源码下载项目说明调试与生成可执行文件核心代码说明总结本节我们使用pythonpywebv

VS配置好Qt环境之后但无法打开ui界面的问题解决

《VS配置好Qt环境之后但无法打开ui界面的问题解决》本文主要介绍了VS配置好Qt环境之后但无法打开ui界面的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 目UKeLvb录找到Qt安装目录中designer.UKeLvBexe的路径找到vs中的解决方案资源

使用Python和Tkinter实现html标签去除工具

《使用Python和Tkinter实现html标签去除工具》本文介绍用Python和Tkinter开发的HTML标签去除工具,支持去除HTML标签、转义实体并输出纯文本,提供图形界面操作及复制功能,需... 目录html 标签去除工具功能介绍创作过程1. 技术选型2. 核心实现逻辑3. 用户体验增强如何运行

CSS 样式表的四种应用方式及css注释的应用小结

《CSS样式表的四种应用方式及css注释的应用小结》:本文主要介绍了CSS样式表的四种应用方式及css注释的应用小结,本文通过实例代码给大家介绍的非常详细,详细内容请阅读本文,希望能对你有所帮助... 一、外部 css(推荐方式)定义:将 CSS 代码保存为独立的 .css 文件,通过 <link> 标签

使用Vue-ECharts实现数据可视化图表功能

《使用Vue-ECharts实现数据可视化图表功能》在前端开发中,经常会遇到需要展示数据可视化的需求,比如柱状图、折线图、饼图等,这类需求不仅要求我们准确地将数据呈现出来,还需要兼顾美观与交互体验,所... 目录前言为什么选择 vue-ECharts?1. 基于 ECharts,功能强大2. 更符合 Vue

Vue中插槽slot的使用示例详解

《Vue中插槽slot的使用示例详解》:本文主要介绍Vue中插槽slot的使用示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、插槽是什么二、插槽分类2.1 匿名插槽2.2 具名插槽2.3 作用域插槽三、插槽的基本使用3.1 匿名插槽