第一阶段: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 元素之后,否则无法正确解析逻辑分支。

相关推荐
一点一木7 小时前
深度体验TRAE SOLO移动端7天:作为独立开发者,我把工作流揣进了兜里
前端·人工智能·trae
天外飞雨道沧桑8 小时前
TypeScript 中 omit 和 record 用法
前端·javascript·typescript
Lee川8 小时前
mini-cursor 揭秘:从 Tool 定义到 Agent 循环的完整实现
前端·人工智能·后端
canonical_entropy9 小时前
从 Spec-Driven Development 到 Attractor-Guided Engineering
前端·aigc·ai编程
研☆香9 小时前
聊聊前端页面的三种长度单位
前端
给钱,谢谢!10 小时前
React + PixiJS 实现果园成长页:从状态机到浇水动画
前端·react.js·前端框架
暗冰ཏོ11 小时前
VUE面试题大全
前端·javascript·vue.js·面试
次元工程师!11 小时前
LangFlow开发(三)—Bundles组件架构设计(3W+字详细讲解)
java·前端·python·低代码·langflow
Bug-制造者12 小时前
现代Web应用全栈开发:从架构设计到部署落地实战
前端
青春喂了后端12 小时前
IntelliGit 前端状态层重构:把一个全局 Store 拆成清晰的状态边界
前端·重构·状态模式