VUE组件学习 | 六、v-if, v-else-if, v-else组件

v-ifv-else-ifv-else 指令基础知识

在 Vue.js 中,v-ifv-else-ifv-else 是一组指令,用于根据表达式的值条件性地渲染元素。

基本语法

html 复制代码
<template>
  <div>
    <!-- 基础条件渲染 -->
    <h1 v-if="type === 'A'">类型 A</h1>
    <h1 v-else-if="type === 'B'">类型 B</h1>
    <h1 v-else>其他类型</h1>

    <!-- 与 `v-for` 一起使用 -->
    <ul>
      <li v-for="item in items" v-if="item.isVisible" :key="item.id">
        {{ item.text }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      type: 'A',
      items: [
        { id: 1, text: 'Item 1', isVisible: true },
        { id: 2, text: 'Item 2', isVisible: false },
        { id: 3, text: 'Item 3', isVisible: true },
      ],
    };
  },
};
</script>

重要注意事项

  1. 条件渲染的优先级v-ifv-else-ifv-else 指令可以连用,形成条件渲染的分支结构。v-ifv-else-if 指令必须紧跟在带有 v-ifv-else-if 的元素之后,而不能被跳过。

  2. v-if 是"真正"的条件渲染 :使用 v-if 的元素只会在相关表达式为真时被渲染并插入 DOM。如果表达式为假,该元素将不会被渲染。

  3. v-else 没有表达式v-else 指令不接受表达式,它仅仅作为 v-ifv-else-if 的"否则"分支。

  4. 使用 v-show 作为替代 :如果你需要频繁切换元素的显示状态,使用 v-show 可能更合适,因为 v-show 只是简单地切换元素的 CSS display 属性。

  5. 避免在 v-for 中使用 v-if :虽然可以在 v-for 中使用 v-if,但这通常不是一个好的做法,因为它会导致每个元素都执行条件检查。如果条件与列表中的项无关,最好使用计算属性来过滤列表。

结论

v-ifv-else-ifv-else 提供了一种强大的方式,根据条件渲染不同的模板部分。通过合理使用这些指令,你可以创建动态且响应用户交互的 Vue.js 应用。

相关推荐
energy_DT21 分钟前
2026年十五五油气田智能增产装备数字孪生,CIMPro孪大师赋能“流动增产工厂”三维可视化管控
前端
斯维赤21 分钟前
每天学习一个小算法:归并排序
学习·算法·排序算法
龙猫里的小梅啊25 分钟前
CSS(四)CSS文本属性
前端·css
椰羊~王小美26 分钟前
实践项目来串联概念(嵌入式、网络、后端、前端、AI)
学习
MXN_小南学前端31 分钟前
watch详解:与computed 对比以及 Vue2 / Vue3 区别
前端·javascript·vue.js
饭小猿人37 分钟前
Flutter实现底部动画弹窗有两种方式
开发语言·前端·flutter
让学习成为一种生活方式1 小时前
pbtk v 3.5.0安装与使用--生信工具084
前端·chrome
三品吉他手会点灯1 小时前
C语言学习笔记 - 15.C编程预备计算机专业知识 - CPU 内存条 硬盘 显卡 主板 显示器 之间的关系
c语言·笔记·学习
heimeiyingwang1 小时前
【架构实战】FinOps云成本优化实践
前端·chrome·架构
三品吉他手会点灯1 小时前
C语言学习笔记 - 11.C语言简介 - VSCode(C/C++)环境安装与配置
c语言·笔记·学习