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

相关推荐
wuhen_n1 小时前
网络请求在Vite层的代理与Mock:告别跨域和后端依赖
前端·javascript·vue.js
小彭努力中1 小时前
193.Vue3 + OpenLayers 实战:圆孔相机模型推算卫星拍摄区域
vue.js·数码相机·vue·openlayers·geojson
用户69371750013846 小时前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦6 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户69371750013846 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水7 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫8 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
jzlhll12310 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
用头发抵命10 小时前
Vue 3 中优雅地集成 Video.js 播放器:从组件封装到功能定制
开发语言·javascript·ecmascript
蓝冰凌10 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js