第一阶段:Vue 基础入门(第 7 天)

Vue 条件渲染:v-ifv-else-ifv-elsev-show 的区别

一、核心知识点
  1. 条件渲染的概念

    通过数据状态的真假值,控制元素在 DOM 中的显示或隐藏。

  2. v-ifv-else-ifv-else 的用法

    • v-if:根据表达式真假创建或销毁元素。

    • v-else-if :作为 v-if 的连续条件分支。

    • v-else :作为 v-ifv-else-if 的默认分支(无需表达式)。

    • 逻辑示例:

      html 复制代码
      <div v-if="score >= 90">优秀</div>
      <div v-else-if="score >= 60">及格</div>
      <div v-else>不及格</div>
  3. v-show 的用法

    通过切换 CSS 的 display: none 控制元素的显隐(元素始终存在于 DOM 中):

    html 复制代码
    <div v-show="isVisible">提示信息</div>
  4. v-if vs v-show 的核心区别

    特性 v-if v-show
    DOM 操作 动态创建/销毁元素 仅切换 display 属性
    初始渲染成本 初始为假时不渲染 无论真假都会渲染
    切换性能 适合不频繁切换的场景 适合频繁切换的场景
    生命周期 触发组件的创建/销毁钩子 不触发生命周期钩子
    <template>支持 支持 不支持

二、案例代码
  1. 多条件分支渲染(v-if/v-else-if/v-else

    html 复制代码
    <template>
      <div>
        <p v-if="score >= 90">成绩优秀!</p>
        <p v-else-if="score >= 70">良好</p>
        <p v-else-if="score >= 60">及格</p>
        <p v-else>需要努力哦</p>
      </div>
    </template>
  2. 显隐控制(v-show

    html 复制代码
    <template>
      <div>
        <button @click="toggle">切换提示</button>
        <p v-show="showTip">这是一个重要提示!</p>
      </div>
    </template>
    <script>
    export default {
      data() {
        return { showTip: true };
      },
      methods: {
        toggle() {
          this.showTip = !this.showTip;
        }
      }
    };
    </script>
  3. 通过开发者工具观察 DOM

    • v-if 为假时:元素从 DOM 中完全移除。
    • v-show 为假时 :元素保留但添加 style="display: none;"

三、总结要点
  1. 选择策略

    • 若元素需要频繁切换显隐 (如弹窗、选项卡),优先使用 v-show 避免重复渲染开销。
    • 若元素无需频繁切换 (如权限控制、静态条件分支),使用 v-if 减少初始 DOM 节点数。
  2. 组合使用
    v-if 系列适合处理互斥逻辑分支 ,而 v-show 适合独立元素的显隐控制。例如:

    html 复制代码
    <div v-if="hasPermission">
      <admin-panel v-show="isPanelVisible"/>
    </div>
  3. 注意事项
    v-else-ifv-else 必须紧跟在 v-ifv-else-if 元素之后,否则无法正确解析逻辑分支。

相关推荐
小叶lr2 分钟前
jenkins打包前端样式丢失/与本地不一致问题
运维·前端·jenkins
浩星8 分钟前
electron系列1:Electron不是玩具,为什么桌面应用需要它?
前端·javascript·electron
ZC跨境爬虫26 分钟前
Scrapy工作空间搭建与目录结构解析:从初始化到基础配置全流程
前端·爬虫·python·scrapy·自动化
小村儿30 分钟前
连载04-最重要的Skill---一起吃透 Claude Code,告别 AI coding 迷茫
前端·后端·ai编程
_院长大人_1 小时前
Vue + ECharts 实现价格趋势分析图
前端·vue.js·echarts
疯笔码良1 小时前
【Vue】自适应布局
javascript·vue.js·css3
浩星1 小时前
electron系列2:搭建专业Electron开发环境
javascript·typescript·electron
IT_陈寒1 小时前
Vite的alias配置把我整不会了,原来是这个坑
前端·人工智能·后端
万物得其道者成2 小时前
Cursor 提效实战:我的前端 Prompt、审查 SKILL、MCP 接入完整方法
前端·prompt
酒鼎2 小时前
学习笔记(12-02)事件循环 - 实战案例 —⭐
前端·javascript