質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.50%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

1989閲覧

Vue.js コンポーネント内の v-for の使いかたについて

orori

総合スコア42

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2018/11/22 05:56

編集2018/11/22 05:59

「Vue.js入門」で学び始めたものです。
P.126 サンプルアプリのコンポーネントですが、以下の通りですと、出力されるのですが、

html

1<script type="text/x-template" id="user-list"> 2 <div> 3 <div v-for="user in users" :key="user.id"> 4 <h2>{{user.name}}</h2> 5 </div> 6 </div> 7</script>

ここから<div></div>要素を削除して以下のようにすると、出力されなくなりました。なぜでしょうか。

html

1<script type="text/x-template" id="user-list"> 2 <div v-for="user in users" :key="user.id"> 3 <h2>{{user.name}}</h2> 4 </div> 5</script>

次に上からv-forを削除して、下のようにしてもオブジェクトにはなりますが、出力されました。

html

1<script type="text/x-template" id="user-list"> 2 <h2>{{users}}</h2> 3</script>

これはv-forの仕様のようなものが関係しているのでしょうか?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

今回のようにtemplateで作成するためには全体を大枠で囲む必要があるみたいです(※vueディレクティブ以外の)。

<script type="text/x-template" id="user-list"> <div>//大枠の役目 <div v-for="user in users" :key="user.id"> <h2>{{user.name}}</h2> </div> </div>//大枠の役目 </script>

大枠がなくなってしまったのでエラー

<script type="text/x-template" id="user-list"> <div v-for="user in users" :key="user.id"> <h2>{{user.name}}</h2> </div> </script>

下は <h2></h2>が大枠になってくれているので、展開されているのです。

<script type="text/x-template" id="user-list"> <h2>//大枠の役目        {{user.name}}       </h2>//大枠の役目 </script>

という私もvue習いたての頃は同じ過ちで躓いていました。

投稿2018/11/22 06:45

編集2018/11/22 06:49
holic

総合スコア134

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

orori

2018/11/22 07:23

回答ありがとうございます!下の方の回答をみますと「すべてのコンポーネントに単一のルート要素が必要」とのことでしたので、コンポーネントの仕様のようですね。
guest

0

ベストアンサー

v-forの仕様ではなく、コンポーネントの仕様だと思います。

Vue.jsのガイド

この「単一のルート要素」の章に書かれている通り、コンポーネントは単一のルート要素が必要です。
ルート要素にv-forを設定してしまうと、ルートが複数(v-forで繰り返される分)になってしまいます。

投稿2018/11/22 06:40

SystemAjisai

総合スコア171

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

orori

2018/11/22 07:24

「コンポーネントは単一のルート要素が必要」とのことですと、今回の場合、<script type="text/x-template" id="user-list"></script>の配下の<div></div>部分がルート要素となり、そこには他の要素を入れてはいけないということですね!なるほど〜〜ありがとうございました!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.50%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問