9cubed
ブログ | PHP | JavaScript | TypeScript | Vue.js | Laravel | Tailwind | Vite | Python | MariaDB | SQLite | Node.js | Linux | PowerShell | Docker | Git | Web | その他 | 将棋ウォーズ | 歌の練習
< 前の記事

v-if(分岐)

次の記事 >

v-once(1度だけ表示)

Vue.js

[Vue.js]v-for(ループ)

公開日:2026-02-20
更新日:2026-02-20

1. 概要

v-for(ループ)で要素を繰り返し表示します。

動作確認:Vite 7.3.1、Vue.js 3.5.25

2. サンプル - 配列をループ

2.1 コード

src/App.vue
コード
<script setup lang="ts">
import { ref } from 'vue';

const fruits = ref([
  { id: 1, name: 'りんご' },
  { id: 2, name: 'みかん' },
  { id: 3, name: 'いちご' },
]);
</script>

<template>
  <ul>
    <li v-for="fruit in fruits" :key="fruit.id">{{ fruit.name }}</li>
  </ul>

  <button @click="fruits.push({ id: fruits.length + 1, name: 'メロン' })">メロンを追加</button>
</template>

実行結果

2.2 説明

v-for は、繰り返し表示したい要素自体に指定します。

:key には一意の ID を指定します。
画面には表示されませんが、リストの再描画で使用されます。
もし指定しなかった場合は、問題が起きる可能性があります。

また、配列が ref の場合、要素に増減があると、自動的に増減があった部分が再描画されます。

3. サンプル2 - オブジェクトをループ

3.1 コード

src/App.vue
コード
<script setup lang="ts">
import { ref } from 'vue';

const user = ref({
  name: '太郎',
  age: 15,
  address: 'Tokyo',
  tel: 'xxxx-xxxx-xxxx'
});
</script>

<template>
  <ul style="text-align:left;">
    <li v-for="(value, key, index) in user" :key="key">{{ index }} : {{ key }}: {{ value }}</li>
  </ul>
</template>

実行結果

3.2 説明

v-for に配列ではなくオブジェクトを渡すと、オブジェクトのプロパティ毎にループすることができます。
上記の場合、name、age、address、tel の4回ループします。
その際に、プロパティ毎の、値、キー(プロパティ名)、インデックスを取得できます。
ループする際の順序は、プロパティを定義した順になります。

4. サンプル3 - 回数を指定してループ

4.1 コード

src/App.vue
コード
<script setup lang="ts">
const count = 5;
</script>

<template>
  <ul style="text-align:left;">
    <li v-for="i in count" :key="i" >{{ i }}</li>
  </ul>
</template>

4.2 説明

ループで出力した要素が増減しないため、key を指定しない場合もあります。
< 前の記事

v-if(分岐)

次の記事 >

v-once(1度だけ表示)

YouTube X

新着一覧

  • async、awaitJavaScript
  • Promise についてJavaScript
  • パッケージの管理Node.js
  • v-model(双方向バインディング)Vue.js
  • VS Code で GitHub を使ったソース管理Git
  • computed(再計算)Vue.js
  • watchDebounced(値の監視)Vue.js
  • watch(値の監視)Vue.js
  • change イベントVue.js
  • v-memoVue.js

アーカイブ

  • 2026/03
  • 2026/02
  • 2026/01
  • 2025/12
  • 2025/11
  • 2025/10
  • 2025/09
  • 2025/08
  • /00

以前のカテゴリー一覧

  • CakePHP3
  • CentOS7
  • HTML・CSS・JavaScript
  • Haskell
  • JavaScript
  • Kotlin
  • Laravel5
  • PHP
  • Python
  • Ruby
  • RubyOnRails5
  • TypeScript
  • Vue.js
  • Webサーバ講座
  • Webプログラミング講座
  • jQuery
  • linux
  • パソコン講座
  • ブログ
  • プログラミング講座
  • メモ帳作成講座
  • 数学

Copyright © 9cubed. All Rights Reserved.

プライバシーポリシー 利用規約
▲