广告
返回顶部
首页 > 资讯 > 精选 >编写Vue v-for循环的方式有哪些
  • 564
分享到

编写Vue v-for循环的方式有哪些

2023-06-22 06:06:13 564人浏览 泡泡鱼
摘要

这篇文章主要讲解了“编写Vue v-for循环的方式有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“编写Vue v-for循环的方式有哪些”吧!这在碰到诸如以下情况时

这篇文章主要讲解了“编写Vue v-for循环的方式有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“编写Vue v-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循环的方式有哪些这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: 编写Vue v-for循环的方式有哪些

本文链接: https://www.lsjlt.com/news/303148.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 编写Vue v-for循环的方式有哪些
    这篇文章主要讲解了“编写Vue v-for循环的方式有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“编写Vue v-for循环的方式有哪些”吧!这在碰到诸如以下情况时...
    99+
    2023-06-22
  • 使用vue v-for循环图片路径方式
    目录v-for循环图片路径v-for循环图片无法显示解决方法v-for循环图片路径 <template> <el-carousel :interval="40...
    99+
    2022-11-13
  • java中for循环的方式有哪些
    Java中for循环的方式有以下几种:1. 基本for循环:在已知循环次数的情况下使用,适用于遍历数组或集合等固定大小的数据结构。`...
    99+
    2023-10-07
    java
  • 编写Vuev-for循环的7种方式
    目录1.始终在v-for循环中使用key2.在一定范围内使用v-for循环3.避免在循环中使用v-if4.使用computed属性或方法5.或者在循环外包一层元素6.访问循环中的索引...
    99+
    2022-11-12
  • php for循环的写法有哪些
    本篇内容主要讲解“php for循环的写法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“php for循环的写法有哪些”吧!php for循环有2种写法,分别是:1、“for(expr1;...
    99+
    2023-06-25
  • Vue中v-for循环key属性注意事项有哪些
    这篇文章将为大家详细讲解有关Vue中v-for循环key属性注意事项有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。当Vue用 v-for 正在更新已渲染过的元素列表...
    99+
    2022-10-19
  • JavaScript For循环的方式有哪几种
    JavaScript中常见的循环方式有以下几种:1. for循环:通过指定初始条件、循环条件和循环增量来执行一系列语句,直到循环条件...
    99+
    2023-09-22
    JavaScript
  • Javascript中for循环语句有哪些写法
    这篇文章主要介绍了Javascript中for循环语句有哪些写法,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。一般写法如下:for(var&...
    99+
    2022-10-19
  • Vue中实现v-for循环遍历图片的方法
    目录v-for循环遍历图片的方法解决方法如下vue循环显示多个图片小扩展(require 和 import)v-for循环遍历图片的方法 写项目时,遇到后台无法提供背景图片,需要自己...
    99+
    2022-11-13
  • vue中v-if和v-for的区别有哪些
    本篇内容主要讲解“vue中v-if和v-for的区别有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue中v-if和v-for的区别有哪些”吧!v-if和v-for的区别:1、作用不同,v...
    99+
    2023-07-04
  • Python使用for实现无限循环的方式有哪些
    这篇文章主要介绍“Python使用for实现无限循环的方式有哪些”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python使用for实现无限循环的方式有哪些”文章能帮助大家解决问题。Python使用...
    99+
    2023-07-05
  • Python中快的循环方式有哪些
    这篇文章主要介绍“Python中快的循环方式有哪些”,在日常操作中,相信很多人在Python中快的循环方式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python中快的循环方式有哪些”的疑惑有所帮助!...
    99+
    2023-07-06
  • Thymeleaf的循环遍历方式有哪些
    这篇文章主要介绍“Thymeleaf的循环遍历方式有哪些”,在日常操作中,相信很多人在Thymeleaf的循环遍历方式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Thymeleaf的循环遍历方式有哪些...
    99+
    2023-07-02
  • foreach和for循环的区别有哪些
    这篇文章主要讲解了“foreach和for循环的区别有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“foreach和for循环的区别有哪些”吧!区别:1、for通过索引来循环遍历每一个数...
    99+
    2023-07-04
  • golang循环遍历map的方式有哪些
    本篇内容介绍了“golang循环遍历map的方式有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!golang循环遍历map的方式有1种,...
    99+
    2023-07-05
  • php中循环数组的方式有哪些
    这篇文章主要介绍“php中循环数组的方式有哪些”,在日常操作中,相信很多人在php中循环数组的方式有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”php中循环数组的方式有哪些”的疑惑有所帮助!接下来,请跟...
    99+
    2023-06-21
  • Mapper编写方式有哪些
    这篇文章给大家分享的是有关Mapper编写方式有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Mapper 编写有哪几种方式?第一种:接口实现类继承 SqlSessionDa...
    99+
    2022-10-19
  • 使用For循环遍历Python字典的方法有哪些
    本篇内容介绍了“使用For循环遍历Python字典的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在Python中,如何使用“fo...
    99+
    2023-06-30
  • Spring解决循环依赖的方式有哪些
    小编给大家分享一下Spring解决循环依赖的方式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!循环依赖就是N个类中循环嵌套引用,如果在日常开发中我们用new...
    99+
    2023-06-16
  • JavaScript循环的方法有哪些
    本篇内容主要讲解“JavaScript循环的方法有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JavaScript循环的方法有哪些”吧! ...
    99+
    2022-10-19
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作