Vue——条件判断、循环遍历

本文详细介绍了Vue中的条件判断和循环遍历。重点讲解了v-if、v-else、v-elseif的使用,以及它们与v-show的区别。在条件判断中,提到了Vue的DOM复用策略及其解决办法。对于循环遍历,文章阐述了v-for如何遍历数组和对象,包括如何使用索引值和属性名。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、条件判断

1. v-if、v-else、v-elseif

v-if用于条件判断,判断Dom元素是否显示。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <title>Document</title>
</head>
<body>
  <div id="app">
    <h2 v-if="isFlag">isFlag为true显示这个</h2>
    <h2 v-show="isShow">isShow为true是显示这个</h2>
    <div v-if="age<18">小于18岁未成年</div>
    <div v-else-if="age<60">大于18岁小于60岁正值壮年</div>
    <div v-else="">大于60岁,暮年</div>
  </div>
  <script src="https://cdn.jsdelivr.net/npm/vue@2.6.10/dist/vue.js"></script>
  <script>
    const app = new Vue({
      el:"#app",
      data:{
        isFlag:true,
        isShow:false,
        age:66
      }
    })
  </script>
</body>
</html>

(1)单独使用v-if,变量为布尔值,为true才渲染Dom

(2)v-show的变量也是布尔值,为true才显示内容,类似css的display

(3)v-if、v-else、v-else-if联合使用相当于if、elseif、else,但是在条件比较多的时候建议使用计算属性。

 2. v-if的demo

​ 在登录网站是经常可以选择使用账户名或者邮箱登录的切

### Vue 2 数组遍历方法 在 Vue 2 中,可以通过多种方式实现数组的遍历。以下是几种常见的方法及其具体示例。 #### 使用 `v-for` 指令 Vue 提供了一个强大的指令——`v-for`,用于基于一组数据渲染列表。通过该指令可以轻松地遍历数组并将其绑定到 DOM 元素上[^2]。 ```html <div id="app"> <ul> <!-- 遍历 books 数组 --> <li v-for="(book, index) in books" :key="index">{{ index }} - {{ book.name }}</li> </ul> </div> <script> var app = new Vue({ el: '#app', data: { books: [ { name: '<<Vue.js>>' }, { name: '<<CSS>>' }, { name: '<<JavaScript>>' } ] } }); </script> ``` 上述代码展示了如何利用 `v-for` 来迭代名为 `books` 的数组,并将每一项显示为 `<li>` 列表中的条目。 --- #### JavaScript 原生方法结合 Vue 数据响应性 除了模板语法外,在脚本部分也可以使用原生 JavaScript 方法来处理数组。需要注意的是,某些方法不会触发 Vue 的响应机制(如直接修改原始数组),因此建议优先选用能够保持响应性的方法[^3]。 ##### 示例:`forEach` 虽然 `forEach` 是一种常用的数组遍历工具,但它仅执行回调函数而无法改变原有数组的内容。如果尝试更新数组内的值,则需重新赋值给目标变量以激活 Vue 的观察器。 ```javascript var a = [1, 2, 3, 4, 5]; a.forEach((item, i) => { this.$set(this.myArray, i, item * 2); // 正确的方式确保响应性 }); // 或者整体替换整个数组 this.myArray = [...a.map(item => item * 2)]; console.log(a); ``` 此处采用 `$set` 显式通知框架某位置发生了变化;或者借助扩展运算符创建新副本从而维持双向同步效果。 --- #### ES6 迭代协议 (`for...of`) 另一种现代浏览器支持的技术是运用增强版循环结构完成相同功能[^4]: ```javascript let arr = [10, 20, 30]; for (let num of arr) { console.log(num); // 输出每一个数字 } ``` 尽管此法适用于纯逻辑计算场景下读取集合成员信息,但在视图层面上仍推荐依赖声明式的 `v-for` 实现更简洁直观的效果。 --- ### 总结 综上所述,对于 Vue 项目而言,“首选方案”无疑是内置的 `v-for` 模板引擎特性,它不仅简化了开发流程还自动维护好关联状态之间的联系关系。与此同时,当遇到复杂业务需求时也可灵活调用底层 API 定制专属解决方案。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值