当前位置: 首页 > article >正文

前端八股Vue(6)---v-if和v-for

目录一、v-for 详解1.1 作用1.2 语法1.3 要点二、v-if 详解2.1 作用2.2 语法2.3 v-if vs v-show三、高频面试坑点v-for 和 v-if 不能用在同一个标签上3.1 错误示例3.2 原因3.3 正确写法四、v-for 里面的 key 作用4.1 一句话核心答案4.2 详细解释4.3 图解有 key vs 无 key4.4 为什么不能用 index 做 key高频考点五、面试标准满分回答Q1v-for 和 v-if 为什么不能一起用Q2v-for 中的 key 有什么作用为什么不能用 index六、总结对比表一、v-for 详解1.1 作用v-for 是循环指令用于遍历数组或对象渲染列表必须绑定 key 提升性能。1.2 语法template !-- 遍历数组 -- div v-for(item, index) in list :keyindex {{ item }} /div !-- 遍历对象 -- div v-for(value, key, index) in obj :keykey {{ key }}: {{ value }} /div !-- 遍历数字1-10 -- div v-forn in 10 :keyn{{ n }}/div !-- 遍历字符串 -- div v-forchar in hello :keychar{{ char }}/div /template1.3 要点要点说明必须绑定 key提高 Vue 复用 DOM、diff 效率可遍历类型数组、对象、数字、字符串参数顺序数组(item, index)对象(value, key, index)二、v-if 详解2.1 作用v-if 是条件渲染指令根据表达式真假创建或销毁 DOM。2.2 语法template !-- 单独使用 -- div v-ifisShow显示/div !-- v-else -- div v-ifisLogin欢迎回来/div div v-else请先登录/div !-- v-else-if -- div v-ifstatus success成功/div div v-else-ifstatus loading加载中/div div v-else失败/div !-- 支持 template 批量渲染 -- template v-ifisShow h2标题/h2 p内容/p /template /template2.3 v-if vs v-show对比v-ifv-show控制方式创建/销毁 DOM切换 display: noneDOM 存在性假时不存在始终存在切换开销高低初始开销低假时不渲染高总是渲染支持 template✅❌支持 v-else✅❌适用场景很少切换频繁切换三、高频面试坑点v-for 和 v-if 不能用在同一个标签上3.1 错误示例!-- ❌ 不推荐 -- div v-foritem in list v-ifitem.isActive :keyitem.id {{ item.name }} /div3.2 原因v-for 优先级比 v-if 高会先循环全部项再逐个判断 v-if造成性能浪费// 本质执行逻辑简化 // 即使只有 1 项符合条件也要遍历全部 1000 条数据 list.forEach(item { if (item.isActive) { // 渲染 DOM } })3.3 正确写法!-- ✅ 方式1在外层套 template -- template v-foritem in list :keyitem.id div v-ifitem.isActive {{ item.name }} /div /template !-- ✅ 方式2提前在 computed 里过滤好数组 -- template div v-foritem in activeList :keyitem.id {{ item.name }} /div /template script setup import { computed } from vue const list ref([...]) const activeList computed(() list.value.filter(item item.isActive) ) /script !-- ✅ 方式3v-show 替代如果只是隐藏 -- div v-foritem in list v-showitem.isActive :keyitem.id {{ item.name }} /div四、v-for 里面的 key 作用4.1 一句话核心答案key 是 Vue 用来识别每个虚拟 DOM 节点的唯一标识方便 Vue 在列表更新时做高效的 DIFF 对比实现 DOM 复用和精准更新提升渲染性能。4.2 详细解释作用说明标识唯一性key 给每个列表项一个唯一 ID让 Vue 知道谁是谁提高 diff 效率有 keyVue 能精准找到变化项只更新该 DOM无 keyVue 只能暴力复用、顺序对比避免渲染错乱删除、逆序、插入时没有 key 容易出现复选框错位、过渡动画混乱4.3 图解有 key vs 无 key无 key索引对比 原列表A B C D 新列表A C D Vue 对比 位置0: A → A ✅ 复用 位置1: B → C ❌ 更新但 B 应该是删除 位置2: C → D ❌ 更新 位置3: D → 无 ❌ 删除 结果2 次更新 1 次删除 有 keyid 对比 原列表A(id:1) B(id:2) C(id:3) D(id:4) 新列表A(id:1) C(id:3) D(id:4) Vue 对比 id:1 存在 ✅ 复用 id:2 不存在 ❌ 删除 id:3 存在 ✅ 复用 id:4 存在 ✅ 复用 结果1 次删除0 次更新4.4 为什么不能用 index 做 key高频考点!-- ❌ 错误用 index 做 key -- div v-for(item, index) in list :keyindex {{ item.name }} input typecheckbox / /div问题操作用 index 作为 key 的问题列表逆序index 变化所有 key 都变了Vue 会重新创建所有 DOM删除/插入后续项的 index 改变导致 DOM 复用错误表单错位input 框的内容会错位因为 key 变了性能大量不必要的 DOM 更新性能反而更差正确做法!-- ✅ 正确用后端返回的唯一 id -- div v-foritem in list :keyitem.id {{ item.name }} /div !-- ✅ 数据没有 id 时可以用 Symbol 或自定义唯一标识 -- div v-for(item, index) in list :keyitem-${item.name}-${item.age} {{ item.name }} /div五、面试标准满分回答Q1v-for 和 v-if 为什么不能一起用答因为 v-for 的优先级高于 v-if如果写在同一个标签上Vue 会先执行循环遍历所有数据再对每一项进行条件判断。这样即使大部分数据都不需要渲染也会先遍历一遍造成性能浪费。正确的做法是用 computed 先过滤数据或者在template外层包一层。Q2v-for 中的 key 有什么作用为什么不能用 index答key 是 Vue 虚拟 DOM diff 算法中识别节点的唯一标识。有 key 时Vue 能精准定位变化项只更新必要的 DOM没有 key 时Vue 只能按顺序对比容易造成错误渲染和性能问题。不能用 index 作为 key因为当列表发生逆序、删除、插入等操作时index 会变化导致 Vue 认为所有节点都变了从而无法复用 DOM反而降低性能还可能导致表单状态错位。应该使用后端返回的唯一 id 作为 key。六、总结对比表指令作用优先级必须配合注意事项v-for循环渲染高:key不要和 v-if 同标签v-if条件渲染中v-else-if/v-else切换开销大key节点标识-配合 v-for不要用 index

相关文章:

前端八股Vue(6)---v-if和v-for

目录 一、v-for 详解1.1 作用1.2 语法1.3 要点二、v-if 详解2.1 作用2.2 语法2.3 v-if vs v-show三、高频面试坑点:v-for 和 v-if 不能用在同一个标签上3.1 错误示例3.2 原因3.3 正确写法四、v-for 里面的 key 作用4.1 一句话核心答案4.2 详细解释4.3 图解&#xf…...

语言的边界,与软件的命运厍

1. 引入 在现代 AI 工程中,Hugging Face 的 tokenizers 库已成为分词器的事实标准。不过 Hugging Face 的 tokenizers 是用 Rust 来实现的,官方只提供了 python 和 node 的绑定实现。要实现与 Hugging Face tokenizers 相同的行为,最好的办法…...

如何将微信聊天记录变为个人数字资产:WeChatMsg完全指南

如何将微信聊天记录变为个人数字资产:WeChatMsg完全指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trending/we/WeC…...

如何给帧数浮动太大的低帧视频插帧?

提示:本视频仅适用于与本文发布时间接近时间发布的剪映电脑版本 你是否遇到过自己的视频帧数浮动太大,看着像PPT? 这一招完美教你的视频不再卡顿! 首先下载这俩软件:剪映和flowframes(下载地址&#xff…...

MD_OnePin:单GPIO引脚实现嵌入式主从通信协议

1. 项目概述MD_OnePin 是一个面向资源受限嵌入式系统的轻量级单线串行通信协议库,其核心设计目标是:仅使用一个通用数字 I/O 引脚(外加共地)即可实现主从式点对点双向数据传输。该库完全基于软件模拟(bit-banging&…...

记录复现多模态大模型论文OPERA的一周工作泄

一、简化查询 1. 先看一下查询的例子 /// /// 账户获取服务 /// /// /// public class AccountGetService(AccountTable table, IShadowBuilder builder) {private readonly SqlSource _source new(builder.DataSource);private readonly IParamQuery _accountQuery build…...

SWTP_CodecLib:轻量级NRF24L01无线协议编解码库

1. SWTP_CodecLib 项目概述SWTP_CodecLib 是一个面向 NRF24L01 射频收发芯片的轻量级通信协议编解码库,其核心目标并非驱动硬件本身,而是为基于 NRF24L01 构建的自定义无线通信系统提供一套结构化、可复用的数据封包与解析机制。该库不依赖特定 MCU 平台…...

保姆级 uPyPi 教程|从 到 :MicroPython 驱动包一键安装 + 分享全攻略诮

这个代码的核心功能是:基于输入词的长度动态选择反义词示例,并调用大模型生成反义词,体现了 “动态少样本提示(Dynamic Few-Shot Prompting)” 与 “上下文长度感知的示例选择” 的能力。 from langchain.prompts impo…...

MySQL锁机制:从全局锁到行级锁的深度解读秤

如果有多个供应商,你也可以使用 [[CC-Switch]] 来可视化管理这些API key,以及claude code 的skills。 # 多平台安装指令 curl -fsSL https://claude.ai/install.sh | bash ## Claude Code 配置 GLM Coding Plan curl -O "https://cdn.bigmodel.cn/i…...

CustomStepper:28BYJ-48裸机步进控制库深度解析

1. CustomStepper 库深度解析:面向嵌入式工程师的 28BYJ-48 精密步进控制实践指南1.1 库定位与工程价值CustomStepper 是一个专为资源受限嵌入式平台设计的轻量级裸机(bare-metal)步进电机控制库,核心目标是为 28BYJ-48 型五相四线…...

详细解析Spring如何解决循环依赖问题蔚

AI训练存储选型的演进路线 第一阶段:单机直连时代 早期的深度学习数据集较小,模型训练通常在单台服务器或单张GPU卡上完成。此时直接将数据存储在训练机器的本地NVMe SSD/HDD上。 其优势在于IO延迟最低,吞吐量极高,也就是“数据离…...

python 文件管理库 Path 解析(详细基础)狼

. GIF文件结构 相比于 WAV 文件的简单粗暴,GIF 的结构要精密得多,因为它天生是为了网络传输而设计的(包含了压缩机制)。 当我们用二进制视角观察 GIF 时,它是由一个个 数据块(Block) 组成的&…...

ORA-06521: PL/SQL映射函数错误,权威解析Oracle报错故障修复与远程处理方案

故障修复核心方案:首先检查PL/SQL代码中的映射函数调用,确保参数类型匹配,避免类型转换错误。执行以下SQL诊断:SELECT * FROM user_errors WHERE name 你的包名; 清理后重编译:ALTER PACKAGE your_package COMPILE; 如…...

Synopsys工具链实战:如何用VCS、DC、ICC和Calibre跑通你的第一个数字IC设计项目?

Synopsys工具链实战:从RTL到GDSII的完整数字IC设计之旅 在芯片设计领域,Synopsys工具链如同一位精密配合的交响乐团指挥,将VCS、Design Compiler、ICC和Calibre等专业工具无缝衔接。本文将带您体验一个完整的设计周期——从最初的RTL代码到最…...

iHRM项目实战

初始化项目环境 创建测试环境,项目文件夹 单接口测试 登录模块 检查步骤: 1.检查方法 2.检查url路径 3.检查请求头Header 4.检查请求体Body 5.检查Test 6.保存 登录成功 你写了断言脚本,但下方Test Results没有显示结果,核…...

【毕业季求生帖】论文盲目降AI等于白送钱?10款降AI软件红黑榜揭秘

今年毕业季,降AI率最大的难点其实早就不仅是降不降得下来,还有降完之后还能不能看,随着知网、维普接连升级AIGC检测算法,靠简单同义词替换已经完全行不通了。 而且最让大家崩溃的往往是这三点:第一,降完之后…...

Raspberry Pi Imager终极指南:告别复杂操作,轻松打造树莓派系统

Raspberry Pi Imager终极指南:告别复杂操作,轻松打造树莓派系统 【免费下载链接】rpi-imager The home of Raspberry Pi Imager, a user-friendly tool for creating bootable media for Raspberry Pi devices. 项目地址: https://gitcode.com/gh_mirr…...

ESP32 PlatformIO I/O扩展驱动:统一抽象与线程安全控制

1. 项目概述htcw_esp_io_expander是一个面向 ESP32 系列微控制器(特别是 ESP32-S2/S3/C3/C6)的 I/O 扩展驱动组件,其本质是将 Espressif 官方 ESP-IDF 组件仓库中io_expander模块封装为 PlatformIO 兼容的独立软件包。该组件并非全新实现&…...

还在为臃肿的视频文件烦恼?这个免费开源工具帮你一键瘦身

还在为臃肿的视频文件烦恼?这个免费开源工具帮你一键瘦身 【免费下载链接】compressO Convert any video/image into a tiny size. 100% free & open-source. Available for Mac, Windows & Linux. 项目地址: https://gitcode.com/gh_mirrors/co/compress…...

三大编程语言深度对比:C# vs 易语言 vs 汇编

C#、易语言和汇编语言是三种定位和应用场景完全不同的编程语言,以下是它们的核心区别对比:特性C#易语言汇编语言语言类型高级面向对象语言中文可视化编程语言低级机器导向语言开发范式支持OOP、函数式等事件驱动中文语法直接操作寄存器/内存执行方式编译…...

数据摄取构建模块简介(预览版)(一)蓉

一、语言特性:Java 26 与模式匹配进化 1.1 Java 26 语言级别支持 IDEA 2026.1 EAP 最引人注目的变化之一,就是新增 Java 26 语言级别支持。这意味着开发者可以提前体验和测试即将在 JDK 26 中正式发布的语言特性。 其中最重要的变化是对 JEP 530 的全面支…...

JetBrains 推出全新开发工具:AI IDE AIR,太炸裂!

当“AI 辅助编程”不再只是一个附加功能,而成为 IDE 的底层架构逻辑,开发工具会进化成什么样?JetBrains 的答案是:不是把 AI 塞进 IDE,而是用 AI 重构 IDE 本身 —— 这就是 AIR(AI IDE from JetBrains&…...

电容是什么?一个“快充快放”的微型充电宝乐

一、前言:什么是 OFA VQA 模型? OFA(One For All)是字节跳动提出的多模态预训练模型,支持视觉问答、图像描述、图像编辑等多种任务,其中视觉问答(VQA)是最常用的功能之一——输入一张…...

电子电路中的“心脏”:电源匕

前言 Kubernetes 本身并不复杂,是我们把它搞复杂的。无论是刻意为之还是那种虽然出于好意却将优雅的原语堆砌成 鲁布戈德堡机械 的狂热。平台最初提供的 ReplicaSets、Services、ConfigMaps,这些基础组件简单直接,甚至显得有些枯燥。但后来我…...

快手Blaze引擎开源:揭秘Spark向量化技术的性能飞跃与生产实践

1. 为什么我们需要Spark向量化引擎? 如果你用过Spark处理大数据,肯定遇到过查询速度慢、资源消耗大的问题。传统Spark执行引擎采用"逐行处理"模式,就像用勺子一勺一勺吃饭——效率低还费劲。而向量化引擎则像用铲子一次铲一大把&am…...

使用 fastkde 对单变量样本进行点密度预测的完整教程

本文详解如何利用 fastkde 库对一维数据集估计核密度,并在任意指定位置(包括原始数据点或新坐标)高效获取密度值,重点介绍 pdf_at_points 的正确用法与实践要点。 本文详解如何利用 fastkde 库对一维数据集估计核密度&#x…...

使用 C# 删除 PDF 中的数字签名藤

一、 什么是 AI Skills:从工具级到框架级的演化 AI Skills(AI 技能) 的概念最早在 Claude Code 等前沿 Agent 实践中被强化。最初,Skills 被视为“工具级”的增强,如简单的文件读写或终端操作,方便用户快速…...

Python如何声明变量_动态类型特性与变量命名规范

Python变量动态创建且类型由值决定,命名须符合规则:仅含字母、数字、下划线,不以数字开头,不能是关键字或内置函数名;区分大小写;支持类型提示但不强制运行时检查。Python 变量不需要声明类型,但…...

传奇开服必看!MonGen.txt脚本这样写能省30%服务器资源

传奇开服性能优化:MonGen.txt脚本高效编写实战指南 在传奇私服架设过程中,服务器资源占用过高是许多GM面临的共同挑战。特别是当玩家数量增加时,M2引擎的CPU和内存使用率飙升,导致游戏卡顿甚至崩溃。本文将深入解析MonGen.txt脚本…...

Arduino_CloudUtils:嵌入式物联网云通信核心工具库

1. Arduino_CloudUtils 库深度解析:嵌入式云通信核心工具链Arduino_CloudUtils 是 Arduino 官方为物联网云连接场景设计的底层通用工具库,其定位并非独立应用框架,而是作为 ArduinoIoTCloud 等上层云 SDK 的“基础设施层”。该库不处理网络协…...