Vue.js 中的 `v-if` 和 `v-show`:理解与应用

简介: Vue.js 中的 `v-if` 和 `v-show`:理解与应用

官网解释

Vue.js 中的 v-if 和 v-show:理解与应用

在Vue.js开发中,v-if和v-show是两个常用的指令,用于控制元素的显示与隐藏。尽管它们在实现效果上相似,但在工作机制和适用场景上却有明显的不同。本文将对比这两个指令,并通过具体案例帮助大家更好地理解和应用它们。

v-if 与 v-show 的工作机制

v-if

v-if是条件渲染指令,它根据表达式的值,来决定是否渲染该元素及其子元素。当表达式为false时,元素从DOM中完全移除,表达式为true时,元素重新渲染并插入DOM。

特点:
  • 完全控制元素的渲染与销毁。
  • 初次加载时不渲染条件为false的元素。
  • 切换条件时有更高的性能消耗,因为会涉及DOM的重新创建和销毁。

v-show

v-show是基于CSS的显示隐藏控制,它通过切换元素的display属性来控制可见性。当表达式为false时,元素的display属性被设置为none,但该元素仍然保留在DOM中。

特点:
  • 控制元素的可见性,但不会移除元素。
  • 初次加载时会渲染所有元素,不论条件为true还是false。
  • 切换条件时性能较好,因为仅仅是切换display属性。

应用案例对比

案例一:登录按钮

假设我们有一个登录按钮,当用户未登录时显示登录按钮,登录后显示退出按钮。

使用 v-if
<template>
  <div>
    <button v-if="!isLoggedIn" @click="login">Login</button>
    <button v-if="isLoggedIn" @click="logout">Logout</button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      isLoggedIn: false,
    };
  },
  methods: {
    login() {
      this.isLoggedIn = true;
    },
    logout() {
      this.isLoggedIn = false;
    },
  },
};
</script>
使用 v-show
<template>
  <div>
    <button v-show="!isLoggedIn" @click="login">Login</button>
    <button v-show="isLoggedIn" @click="logout">Logout</button>
  </div>
</template>
<script>
export default {
  data() {
    return {
      isLoggedIn: false,
    };
  },
  methods: {
    login() {
      this.isLoggedIn = true;
    },
    logout() {
      this.isLoggedIn = false;
    },
  },
};
</script>

案例二:切换大数据表格

假设我们有一个大数据表格,在用户点击按钮时显示表格,再次点击时隐藏表格。

使用 v-if
<template>
  <div>
    <button @click="toggleTable">Toggle Table</button>
    <table v-if="showTable">
      <!-- 假设这里有很多行数据 -->
    </table>
  </div>
</template>
<script>
export default {
  data() {
    return {
      showTable: false,
    };
  },
  methods: {
    toggleTable() {
      this.showTable = !this.showTable;
    },
  },
};
</script>
使用 v-show
<template>
  <div>
    <button @click="toggleTable">Toggle Table</button>
    <table v-show="showTable">
      <!-- 假设这里有很多行数据 -->
    </table>
  </div>
</template>
<script>
export default {
  data() {
    return {
      showTable: false,
    };
  },
  methods: {
    toggleTable() {
      this.showTable = !this.showTable;
    },
  },
};
</script>

使用建议

  • 使用 v-if:适用于条件变化不频繁,或初始状态为false时不需要渲染该元素的情况。例如,切换整个页面或模块。
  • 使用 v-show:适用于需要频繁切换显示隐藏状态的元素,因为它不会销毁和重建DOM结构。例如,切换标签页或简单的显示隐藏效果。

通过这篇文章,相信大家对v-if和v-show的区别和使用场景有了更清晰的认识。希望这些案例能帮助大家在实际开发中做出更合适的选择。如果你有任何问题或见解,欢迎在评论区与我们分享讨论!

相关文章
|
6天前
|
JavaScript 前端开发 API
详解队列在前端的应用,深剖JS中的事件循环Eventloop,再了解微任务和宏任务
该文章详细讲解了队列数据结构在前端开发中的应用,并深入探讨了JavaScript的事件循环机制,区分了宏任务和微任务的执行顺序及其对前端性能的影响。
|
6天前
|
缓存 JavaScript 前端开发
vue-day02计算属性,v-bind,v-if,v-for
文章介绍了Vue.js中的计算属性、class与style的绑定、条件渲染和列表渲染的使用。通过示例代码展示了如何使用计算属性简化模板逻辑、如何通过v-bind动态绑定class和style、如何使用v-if进行条件渲染以及如何使用v-for进行列表渲染。这些特性使得Vue.js在构建动态用户界面时更加灵活和强大。
vue-day02计算属性,v-bind,v-if,v-for
|
7天前
|
JavaScript 开发者
深入理解Node.js事件循环及其在后端开发中的应用
【8月更文挑战第57天】本文将带你走进Node.js的事件循环机制,通过浅显易懂的语言和实例代码,揭示其背后的工作原理。我们将一起探索如何高效利用事件循环进行异步编程,提升后端应用的性能和响应速度。无论你是Node.js新手还是有一定经验的开发者,这篇文章都能给你带来新的启发和思考。
|
6天前
|
自然语言处理 JavaScript 前端开发
JS中this的应用场景,再了解下apply、call和bind!
该文章深入探讨了JavaScript中`this`关键字的多种应用场景,并详细解释了`apply`、`call`和`bind`这三个函数方法的使用技巧和差异。
|
11天前
|
自然语言处理 前端开发 JavaScript
探索JavaScript中的闭包及其实际应用
本文深入探讨了JavaScript中闭包的概念、特性及其在实际项目中的应用。通过具体示例,详细讲解了闭包的创建方法和用途,揭示了闭包在数据保护和模块化开发中的重要性。同时,还讨论了闭包可能带来的内存管理问题及优化策略,为前端开发者提供了全面的闭包知识和实践指导。
|
20天前
|
自然语言处理 JavaScript 前端开发
探索JavaScript中的闭包:从基础概念到实际应用
本文深入探讨了JavaScript中闭包的概念,从定义、作用域链和实际应用等方面进行了详细阐述。通过生动的比喻和实例代码,帮助读者理解闭包在函数执行上下文中的重要性,以及如何在实际开发中有效利用闭包解决复杂问题。同时,文章也指出了过度使用闭包可能导致的潜在问题,并给出了相应的优化建议。
|
29天前
|
JavaScript API 数据库
深入理解Node.js事件循环及其在后端开发中的应用
【9月更文挑战第3天】本文将深入浅出地介绍Node.js的事件循环机制,探讨其非阻塞I/O模型和如何在后端开发中利用这一特性来处理高并发请求。通过实际的代码示例,我们将看到如何有效地使用异步操作来优化应用性能。文章旨在为读者揭示Node.js在后端开发中的核心优势和应用场景,帮助开发者更好地理解和运用事件循环来构建高性能的后端服务。
|
6天前
|
JavaScript 前端开发 开发者
深入浅出 Vue.js:构建响应式前端应用
Vue.js 是一个流行的前端框架,以其简洁、高效和易学著称。它采用响应式和组件化设计,简化了交互式用户界面的构建。本文详细介绍 Vue.js 的核心概念、基本用法及如何构建响应式前端应用,包括实例、模板、响应式数据和组件等关键要素,并介绍了项目结构、Vue CLI、路由管理和状态管理等内容,帮助开发者高效地开发现代化前端应用。
|
1月前
|
缓存 JavaScript 前端开发
JavaScript模块化开发:ES6模块与CommonJs的对比与应用
JavaScript模块化开发:ES6模块与CommonJs的对比与应用
21 2
|
2月前
|
机器学习/深度学习 存储 前端开发
实战揭秘:如何借助TensorFlow.js的强大力量,轻松将高效能的机器学习模型无缝集成到Web浏览器中,从而打造智能化的前端应用并优化用户体验
【8月更文挑战第31天】将机器学习模型集成到Web应用中,可让用户在浏览器内体验智能化功能。TensorFlow.js作为在客户端浏览器中运行的库,提供了强大支持。本文通过问答形式详细介绍如何使用TensorFlow.js将机器学习模型带入Web浏览器,并通过具体示例代码展示最佳实践。首先,需在HTML文件中引入TensorFlow.js库;接着,可通过加载预训练模型如MobileNet实现图像分类;然后,编写代码处理图像识别并显示结果;此外,还介绍了如何训练自定义模型及优化模型性能的方法,包括模型量化、剪枝和压缩等。
33 1
下一篇
无影云桌面