How to Loop Through an Array In Vue Using V-For?

9 minutes read

In Vue.js, you can use the v-for directive to loop through an array and dynamically render elements on the HTML template.


To loop through an array in Vue using v-for, you can follow these steps:

  1. Start by adding a data property to your Vue component that holds the array you want to loop through. For example, let's say you have an array of names: data() { return { names: ['John', 'Jane', 'Bob', 'Alice'], }; },
  2. In your HTML template, use the v-for directive to iterate over the array and render elements dynamically. You can use the v-for directive on any DOM element or component.
    • :key="name">{{ name }}
    In the example above, we iterate over the names array using v-for="name in names". The name variable represents the current item from the array being iterated. We use the :key attribute to provide a unique identifier for each rendered element.
  3. Vue will automatically render an
  4. element for each item in the names array, displaying the name in the list.
    • John
    • Jane
    • Bob
    • Alice
    This is how you can loop through an array in Vue using v-for. You can also access the index of the current item, as well as other properties or methods within the loop if needed.

Best Vue.js Books to Read in 2025

1
Vue.js in Action

Rating is 5 out of 5

Vue.js in Action

2
Vue.js 3 Cookbook: Discover actionable solutions for building modern web apps with the latest Vue features and TypeScript

Rating is 4.9 out of 5

Vue.js 3 Cookbook: Discover actionable solutions for building modern web apps with the latest Vue features and TypeScript

3
Front-End Development Projects with Vue.js: Learn to build scalable web applications and dynamic user interfaces with Vue 2

Rating is 4.8 out of 5

Front-End Development Projects with Vue.js: Learn to build scalable web applications and dynamic user interfaces with Vue 2

4
Vue.js 3 By Example: Blueprints to learn Vue web development, full-stack development, and cross-platform development quickly

Rating is 4.7 out of 5

Vue.js 3 By Example: Blueprints to learn Vue web development, full-stack development, and cross-platform development quickly

5
Vue.js: Up and Running: Building Accessible and Performant Web Apps

Rating is 4.6 out of 5

Vue.js: Up and Running: Building Accessible and Performant Web Apps

6
Hands-on Nuxt.js Web Development: Build universal and static-generated Vue.js applications using Nuxt.js

Rating is 4.5 out of 5

Hands-on Nuxt.js Web Development: Build universal and static-generated Vue.js applications using Nuxt.js

7
Jump Start Vue.js

Rating is 4.4 out of 5

Jump Start Vue.js


How to loop through an array in reverse order using v-for in Vue?

To loop through an array in reverse order using v-for in Vue, you can use the v-for directive along with the reverse() method of the array. Here's an example:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<template>
  <div>
    <ul>
      <li v-for="item in reverseArray" :key="item.id">
        {{ item.name }}
      </li>
    </ul>
  </div>
</template>

<script>
export default {
  data() {
    return {
      array: [
        { id: 1, name: 'Item 1' },
        { id: 2, name: 'Item 2' },
        { id: 3, name: 'Item 3' },
      ]
    }
  },
  computed: {
    reverseArray() {
      // Reverse the original array
      return this.array.reverse();
    }
  }
}
</script>


In the above example, the reverseArray computed property is used to reverse the original array using the reverse() method. Then, the v-for directive is used to loop through the reverseArray and display each item in reverse order.


Note that using reverse() method directly on the array will change the original array order. So it is recommended to use a computed property to generate the reversed array if you want to keep the original array intact.


How to loop through an array in Vue with nested templates using v-for?

To loop through an array in Vue with nested templates using v-for, you can use the nested v-for directive. Here's an example:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
<template>
  <div>
    <div v-for="(item, index) in items" :key="index">
      <h2>{{ item.name }}</h2>
      <ul>
        <li v-for="(subItem, i) in item.subItems" :key="i">
          {{ subItem.text }}
        </li>
      </ul>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      items: [
        {
          name: "Item 1",
          subItems: [
            { text: "Sub Item 1" },
            { text: "Sub Item 2" },
            { text: "Sub Item 3" }
          ]
        },
        {
          name: "Item 2",
          subItems: [
            { text: "Sub Item 4" },
            { text: "Sub Item 5" },
            { text: "Sub Item 6" }
          ]
        },
        {
          name: "Item 3",
          subItems: [
            { text: "Sub Item 7" },
            { text: "Sub Item 8" },
            { text: "Sub Item 9" }
          ]
        }
      ]
    };
  }
};
</script>


In this example, we have an array called "items" with each item containing a name and a subItems array. We use v-for to loop through the "items" array and for each item, we display its name and loop through the "subItems" array to display each sub item's text.


The key property is used to provide a unique identifier for each rendered element in the v-for loop, which helps Vue efficiently update the DOM when the array changes.


Note: Make sure to use unique keys for each item in the v-for loop to optimize the rendering performance.


How to loop through a filtered array using v-for in Vue?

To loop through a filtered array using v-for in Vue, you can follow these steps:

  1. Create a computed property that filters the array based on your desired condition. For example:
1
2
3
4
5
computed: {
  filteredArray() {
    return this.array.filter(item => item.condition === 'value');
  }
}


  1. In your template, use v-for to iterate over the computed property:
1
2
3
<div v-for="item in filteredArray" :key="item.id">
  {{ item.name }}
</div>


In this example, the computed property filteredArray will return a new array with only the items that meet the specified condition. The v-for directive will then loop through this filtered array, rendering the desired elements in the template.


How to access the current iteration's index in v-for in Vue?

In Vue, you can access the current iteration's index in a v-for loop by using the second argument provided to the v-for directive.


Here's an example:

1
2
3
4
5
<ul>
  <li v-for="(item, index) in items" :key="index">
    {{ index }}: {{ item }}
  </li>
</ul>


In the above example, the index is the second argument of the v-for directive ((item, index)). This index can be used inside the loop to access the current iteration's index. The :key attribute is also used to provide a unique identifier for each rendered element, which improves rendering performance.


You can then use {{ index }} to display the current iteration's index within the loop.


Note: The v-for loop starts the index from 0 by default, but you can set it to start from a different number using a computed property or a method.


What is the shorthand syntax for using v-for in Vue?

The shorthand syntax for using v-for in Vue is using an alias.


Here is the shorthand syntax:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
<!-- Iterating an array -->
<ul>
  <li v-for="item in items" :key="item.id">
    {{ item.name }}
  </li>
</ul>

<!-- Iterating an object -->
<div v-for="(value, key) in object" :key="key">
  {{ key }}: {{ value }}
</div>


In the above examples, item is the alias for each item in the items array, and value and key are the aliases for the values and keys of each property in the object object.

Facebook Twitter LinkedIn Telegram

Related Posts:

In Vue.js, routing can be set up to navigate between different pages within a single-page application. To implement routing in a Vue.js application, you need to follow a set of steps:Install the Vue Router package via npm or yarn by running the following comma...
To create a new Vue instance, follow these steps:First, include the Vue library in your HTML file. You can do this by including the Vue CDN script tag: Define a new HTML element where you want to mount your Vue instance: Create a new Vue instance by calling th...
To bind data to the DOM in Vue.js, you can utilize Vue&#39;s data binding syntax and directives. This allows you to establish a connection between the data in your Vue instance and the DOM elements in your template.To bind data from your Vue instance to the DO...