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

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

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

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

JavaScript

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

Q&A

1回答

1341閲覧

親コンポーネントで格納したデータを子コンポーネントに反映できないです。(vue.js)

kaksji

総合スコア17

Vue.js

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

JavaScript

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

0グッド

0クリップ

投稿2019/05/12 11:04

前提・実現したいこと

投稿したデータをストアで格納して、投稿一覧のページに投稿テンプレートとして表示したいです。
初歩的な質問にはなるとは思いますが、御教示頂けますと幸いです。

発生している問題・エラーメッセージ

エラーメッセージ

該当のソースコード

post.vue(投稿フォーム) <template> <v-card-text> <v-form> <v-textarea v-model="post" label="学んだ事" outline></v-textarea> <v-btn class="primary" @click="submit" >投稿</v-btn> <v-btn class="accent">削除</v-btn> </v-form> </v-card-text> </template> <script> import { mapActions } from 'vuex' export default { data () { return { post: [] } }, methods: { submit () { this.addPost(this.post) this.$router.push({name:'postsList'}) this.post = [] }, ...mapActions(['addPost']) } } </script> post.list(投稿一覧) <template> <!-- <router-link :to="{ name: 'postsList' }"> --> <v-card-text> <v-form> <v-textarea :items='posts' label="学んだ事" outline> <template v-slot:items="props"> <td class="text-xs-left">{{ props.item.posts }}</td> </template> </v-textarea> <!-- </router-link> --> </v-form> </v-card-text> </template> <script> export default { created () { // 連絡先のデータをストアに取り行くようにする this.posts = this.$store.state.posts }, data (){ return { posts: [] } } } </script> store.js Vue.use(Vuex) export default new Vuex.Store({ state: { posts: [] }, mutations: { addPost (state, post) { state.posts.push(post) } }, // コンポーネントのインターフェイスとなる部分 actions: { // ミューテーションにpostを受け渡す addPost ({commit}, post) { commit('addPost', post) } },

試したこと

ここに問題に対して試したことを記載してください。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

Vuexストアのstateを参照したい場合はcomputedプロパティに記述しましょう。
提示されているコードの場合ですと、createdライフサイクルの後にstateに変更があった場合に変更が画面に反映されません。

また配列の内容を表示したい場合はv-forを使ってリストレンダリングしましょう。

以上のことを踏まえて一覧ページのコードを簡略化すると下記のような感じになります。

vue

1<template> 2 <div v-for="(post, index) in posts" :key="index"> 3 {{ post }} 4 </div> 5</template> 6 7<script> 8import { mapState } from 'vuex' 9 10export default { 11 computed: { 12 ...mapState(['posts']) 13 } 14} 15</script>

投稿2019/05/13 05:49

編集2019/05/13 05:50
yhg

総合スコア2161

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

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

kaksji

2019/05/13 07:54

拙い質問ではありましたが、返信いただきありがとうございます。 v-forを使用し配列postsの値を投稿一覧ページに値を反映することが出来ました。 ありがとうございます。 私の言葉足らずで大変恐縮ですが、掲示板のように配列postsの値とテンプレート(post.vue(投稿フォーム))のセットでレンダリングできる方法を御教示いただければと思っていました。 もし宜しければその方法を御教示頂けますと幸いです。
yhg

2019/05/13 09:24

同じ画面に投稿フォームと投稿一覧を表示したいということでしたら、両方を一緒に表示するコンポーネントを新たに作って、作ったコンポーネントをvue-router経由で表示すれば良いと思います。 <template> <div> <posts-list /> <post-form /> </div> </template>
kaksji

2019/05/13 11:26 編集

返信ありがとうございます。 申し訳ありません。 度々の言葉足らずで、、 投稿フォームと投稿一覧は別画面です。 下記ファイルです。 ・post.vue(投稿フォーム) ・post.list(投稿一覧) 投稿フォームで入力したデータを投稿一覧で掲示板のように表示したいのですが、先ほどいただいたコードだけですと、データのみ反映されます。 下記実際の挙動になります。 https://gyazo.com/0d67fe2f356c7fdc19211f7065f74e41 最後に映った投稿カードを掲示板のようにデータと共に繰り返し表示したいです。 uiはフェイスブックの方がイメージ近いです。 下記頂いたソースコードを元に編集した投稿一覧フォーム postlist.vue(投稿一覧) <template> <v-layout> <v-flex xs12 sm6 offset-sm3> <v-card> <v-img src="https://cdn.pixabay.com/photo/2015/11/19/21/14/phone-1052023__480.jpg" aspect-ratio="2.75" ></v-img> <v-card-title primary-title> <div> <h3 class="headline mb-0">今日学んだこと</h3> <div> <div v-for="(post, index) in posts":key="index" > {{ post }} </div> </div> </div> </v-card-title> <v-card-actions> <v-btn flat color="orange">Share</v-btn> <v-btn flat color="orange">delete</v-btn> </v-card-actions> </v-card> </v-flex> </v-layout> </template> <script> import { mapState } from 'vuex' export default { computed: { ...mapState(['posts']) } } </script>
yhg

2019/05/13 13:26

私が提示したコードは配列の内容を表示するだけの簡略化した例なのでそのまま流用はできません。 今回の場合ですと、<v-flex>にv-forを書く必要がありますね。 差し出がましいですが、きちんと意味を理解して書けるよう、Vue公式ガイドを読んでみてはいかがでしょうか。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問