编写 Vue v-for 循环的 7 种方式

 更新时间:2021年12月30日 11:21:14   作者:耀_  
这篇文章主要分享可编写 Vue v-for 循环的 7 种方式,在Vue中,基本上每个项目都会用到v-for循环。它们允许你在模板代码中编写for循环,接下来一起看看下面文章的详细介绍吧

这在碰到诸如以下情况时特别好用:

  • 渲染数组或列表
  • 遍历对象属性

在Vue中v-for循环最基本的用法是这样的:

<ul>
  <li v-for='product in products'>
    {{ product.name }}
  </li>
</ul>


但是,在本文中,我们将介绍一些超棒的方法,可以使你的v-for代码更加精确、可预测和高效。

让我们开始吧。

1. 始终在v-for循环中使用key

首先,我们讨论的是大多数Vue开发人员已经知道的常见最佳实践——在v-for循环中使用:key。通过设置唯一的键属性,可以确保组件按期望的方式工作。

如果我们不使用:key,Vue将使DOM尽可能高效。这可能会导致v-for元素出现乱序或其他不可预测的行为。

如果我们对每个元素都有唯一的键引用,那么就可以更好地预测如何操纵DOM。

<ul>
  <li 
    v-for='product in products'
    :key='product._id'  
  >
    {{ product.name }}
  </li>
</ul>


2. 在一定范围内使用v-for循环

虽然大多数时候v-for用于循环数组或对象,但也有我们只想迭代特定次数的情况。

例如,假设我们正在为在线商店创建分页系统,并且我们只想每页显示10个产品。使用变量来跟踪当前页码,就可以像这样处理分页。

<ul>
  <li v-for='index in 10' :key='index'>
    {{ products[page * 10 + index] }}
  </li>
</ul>


3. 避免在循环中使用v-if

一个超常见的错误是使用v-if来过滤v-for循环的数据。

虽然看上去直观了,但这会导致一个巨大的性能问题——VueJS将优先v-for于v-if指令。

这意味着组件将遍历每个元素,然后再检查v-if条件以查看是否应该呈现。

如果你将v-if与v-for一起使用,无论条件是什么,都将遍历数组的每一项。

// 不好的做法!
<ul>
  <li 
    v-for='product in products' 
    :key='product._id' 
    v-if='product.onSale'
  >
    {{ product.name }}
  </li>
</ul>


那么问题是什么?

假设products数组有数千个项,但想要渲染的只有3个在售产品。

每次重新渲染时,即使出售的3种产品根本没有改变,Vue也必须遍历这数千个项。

必须尽量避免结合使用v-if与v-for的情况。

接下来介绍两个替代方法。

4. 使用computed属性或方法

为了避免上述问题,我们应该在模板中进行迭代之前过滤数据。有两种非常相似的方法可以做到:

  • 使用computed属性
  • 使用过滤方法

随你选择,下面让我们快速介绍这两个方法。

首先,我们只需要设置一个computed属性。为了获得与之前的v-if相同的功能,代码看起来像这样。

<template>
  <ul>
    <li v-for="products in productsOnSale" :key="product._id">
      {{ product.name }}
    </li>
  </ul>
</template>

<script>
  export default {
    data () {
      return {
        products: []
      }
    },
    computed: {
      productsOnSale: function () {
        return this.products.filter(product => product.onSale)
      }
    }
  }
</script>

这样的好处是:

  • 数据属性只会在依赖项发生变化时重新评估
  • 模板只遍历在售的产品,而不是每一个产品

使用过滤方法的代码几乎相同,但使用方法会改变访问模板内值的方式。但是,如果我们希望能够将变量传递给过滤过程,那么就应该选择方法这条路。

<template>
  <ul>
    <li v-for="products in productsOnSale(50))" :key="product._id">
      {{ product.name }}
    </li>
  </ul>
</template>

<script>
  export default {
   data () {
    return {
     products: []
    }
   },
   methods: {
    productsOnSale (maxPrice) {
     return this.products.filter(product => product.onSale && product.price < maxPrice)
    }
   }
  }
</script>


5. 或者在循环外包一层元素

在决定是否完全渲染列表时,你可能还是想要将v-forv-if结合起来。

例如,如果我们只想在用户登录时呈现产品列表怎么办。

错误代码:

<ul>
  <li 
    v-for='product in products' 
    :key='product._id' 
    v-if='isLoggedIn' <!-- HERE -->
  >
    {{ product.name }}
  </li>
</ul>


这有什么问题?

和之前一样。Vue模板会优先考虑v-for——所以会遍历每个元素并检查v-if

即使最后什么都不渲染,也会循环数千个元素。

对于此示例,有一个简单的解决方案是移动v-if语句。

更好的代码!

<ul v-if='isLoggedIn'> <!-- Much better -->
  <li 
    v-for='product in products' 
    :key='product._id' 
  >
    {{ product.name }}
  </li>
</ul>


这要好得多,因为如果isLoggedInfalse——那就根本不需要迭代。

6. 访问循环中的索引

除了遍历数组并访问每个元素之外,我们还可以跟踪每个项目的索引。

为此,我们需要在项目之后添加一个索引值。这样做超级简单,但对于分页、显示列表索引、显示排名等都很有用。

<ul>
  <li v-for='(products, index) in products' :key='product._id' >
    Product #{{ index }}: {{ product.name }}
  </li>
</ul>


7. 迭代对象

到目前为止,我们只研究了使用v-for来遍历数组。但是我们也可以很轻松地学会迭代对象的键值对。

与访问元素的索引类似,我们需要向循环中添加另一个值。如果我们使用单个参数循环对象,我们将循环所有项。

如果我们添加另一个参数,则将获得项和键。如果我们添加第三个参数,则还可以访问v-for循环的索引。

假设我们想遍历产品中的每个属性。那么代码如下:

<ul>
  <li v-for='(products, index) in products' :key='product._id' >
    <span v-for='(item, key, index) in product' :key='key'>
      {{ item }}
    </span>
  </li>
</ul>


结论:
希望这篇文章能帮助你学到一些关于使用Vue v-for指令的最佳实践。

到此这篇关于编写 Vue v-for 循环的 7 种方式的文章就介绍到这了,更多相关 Vue v-for 循环的  方式内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue3不能使用history.pushState修改url参数踩坑

    vue3不能使用history.pushState修改url参数踩坑

    这篇文章主要为大家介绍了vue3不能使用history.pushState修改url参数踩坑解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-02-02
  • 关于Vue虚拟dom问题

    关于Vue虚拟dom问题

    这篇文章主要介绍了Python合成Excel表的实现代码(多sheet),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-04-04
  • vue中el-table树状表格末行合计实现

    vue中el-table树状表格末行合计实现

    本文主要介绍了vue中el-table树状表格末行合计实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-11-11
  • Vue3使用ref和reactive管理状态的代码示例

    Vue3使用ref和reactive管理状态的代码示例

    ref 和 reactive 是 Composition API 中用来声明响应式数据的两个核心函数,在 Vue 3 中,使用 setup 语法糖可以更简洁地使用这些功能,本文将探讨如何使用 ref 和 reactive 来管理状态,并解释它们之间的区别,需要的朋友可以参考下
    2024-09-09
  • vue时间戳和时间的相互转换方式

    vue时间戳和时间的相互转换方式

    本文通过示例代码介绍了vue时间戳和时间的相互转换方式,通过场景分析介绍了vue3使用组合式api将时间戳格式转换成时间格式(2023年09月28日 10:00),感兴趣的朋友一起看看吧
    2023-12-12
  • 在Vue中实现网页截图与截屏功能详解

    在Vue中实现网页截图与截屏功能详解

    在Web开发中,有时候需要对网页进行截图或截屏,Vue作为一个流行的JavaScript框架,提供了一些工具和库,可以方便地实现网页截图和截屏功能,本文将介绍如何在Vue中进行网页截图和截屏,需要的朋友可以参考下
    2023-06-06
  • Vue2.0利用vue-resource上传文件到七牛的实例代码

    Vue2.0利用vue-resource上传文件到七牛的实例代码

    本篇文章主要介绍了Vue2.0利用vue-resource上传文件到七牛的实例代码,具有一定的参考价值,有兴趣的可以了解一下
    2017-07-07
  • Vue3请求拦截器里如何配置token

    Vue3请求拦截器里如何配置token

    这篇文章主要介绍了Vue3请求拦截器里如何配置token,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Vue获取表单数据的方法

    Vue获取表单数据的方法

    这篇文章主要为大家介绍了Vue获取表单数据的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2021-12-12
  • 前端H5微信支付宝支付实现方法(uniapp为例)

    前端H5微信支付宝支付实现方法(uniapp为例)

    最近上线一个项目,手机网站进行调起支付宝App支付,做起来还是满顺手的,在此做个记录,这篇文章主要给大家介绍了关于前端H5微信支付宝支付实现方法的相关资料,需要的朋友可以参考下
    2024-04-04

最新评论