🎯v-for 先还是 v-if 先?Vue2/3 编译真相

代码 + 编译结果 把差异讲透。


1. Vue2 的优先级:v-for 先于 v-if

1.1 源码层面

Vue2 的模板编译器在解析 AST 时,会把 v-for 节点标记为 父节点v-if 标记为 子节点 (或同级节点),因此 循环先执行,条件判断后执行。

1.2 编译结果

vue 复制代码
<template>
  <div v-for="i in 100" v-if="i % 2 === 0">{{ i }}</div>
</template>

编译后(简化伪码):

js 复制代码
_render() {
  return _l(100, i => i % 2 === 0 ? _c('div', i) : null);
}
  • _lv-for 渲染函数,先循环 100 次 ,再逐条判断 i % 2
  • 后果
    • 生成 100 个虚拟 DOM 节点,其中 50 个 null 被丢弃。
    • 多余计算内存浪费首屏白屏时间变长

2. Vue3 的优先级:v-if 先于 v-for

2.1 编译结果

Vue3 模板编译器把 v-if 提升到 父级节点v-for 退到 子级节点

上例编译后:

js 复制代码
_render() {
  return (_l(
    (100).filter(i => i % 2 === 0), // 先过滤
    i => _c('div', i)
  ));
}
  • 先过滤再循环,只生成 50 个有效节点。
  • 零多余计算,直接渲染正确结果。

3. 差异后果总结

  • Vue2:先循环后判断 → 渲染多余节点 → 性能下降。
  • Vue3:先判断后循环 → 零浪费 → 性能提升。

4. 最佳实践

  • Vue2computed 提前过滤,避免性能陷阱。
  • Vue3直接写即可,无需额外处理。
相关推荐
小码哥_常3 分钟前
安卓黑科技:实现多平台商品详情页一键跳转APP
前端
killerbasd7 分钟前
还是迷茫 5.3
前端·react.js·前端框架
不会敲代码11 小时前
TCP/IP 与前端性能:从数据包到首次渲染的底层逻辑
前端·tcp/ip
kyriewen1 小时前
奥特曼借GPT-5.5干杯,而你的Copilot正按Token收钱
前端·github·openai
AC赳赳老秦1 小时前
投标合规提效:用 OpenClaw 实现标书 / 合同自动审核、关键词校验、格式优化,降低废标风险
开发语言·前端·python·eclipse·emacs·deepseek·openclaw
kyriewen1 小时前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
前端·javascript·设计模式
不会敲代码12 小时前
从零搭建 AI 日记助手:用 Milvus 向量数据库实现语义搜索
javascript·openai
千寻girling2 小时前
《 Git 详细教程 》
前端·后端·面试
threelab3 小时前
Three.js UV 图像变换效果 | 三维可视化 / AI 提示词
javascript·人工智能·uv
之歆3 小时前
DAY08_CSS浮动与行内块布局实战指南(下)
前端·css