🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Vue.js

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

Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

982閲覧

Rails APIで取得したデータをリアルタイムで画面に反映させたい。

Khy

総合スコア118

Vue.js

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

Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2019/11/15 11:54

練習でRails APIとNuxt.jsを使用したWebアプリケーションを作成しております。

Nuxt.jsは以下のコードようになっており、テキストフィールドに文字を入力して送信を押すとPOSTでRails APIを叩いてデータベースにデータを保存する形になっております。

送信ボタンを押した際にデータはちゃんとデータベースに追加されるのですが、画面の表示が変わりません。
ページをリロードして初めて追加したデータが表示されます。

送信ボタンを押した際に画面上に追加したデータが表示されるようにするにはどうしたらよいでしょうか?

<template> <div> <ul> <li v-for="(data, index) in datas" :key="data.name">{{ index }}{{ data.name }}</li> </ul> <input v-model="newData" /> <p @click="register">送信</p> </div> </template> <script> export default { data() { return { datas: "", newData: "" }; }, async asyncData({ $axios }) { const response = await $axios .$get("http://localhost:3000/api/v1/users") .catch(error => { console.log("response error", error); return false; }); return { datas: response.data }; }, methods: { register() { this.$axios.post("http://localhost:3000/api/v1/users", { name: this.newData }); const response = this.$axios .$get("http://localhost:3000/api/v1/users") .catch(error => { console.log("response error", error); return false; }); return { datas: response.data }; } } }; </script>

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

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

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

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

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

guest

回答1

0

ベストアンサー

この場合 register() は値を返して何かを出力するわけではなく、 datasを更新して画面に反映させたいので、returnではなく this.datas = response.data してあげればよいと思います。

投稿2019/11/16 15:05

編集2019/11/16 15:06
8zca

総合スコア559

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

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

Khy

2019/11/17 10:40

なるほどです!無事解決いたしました。 ご回答ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問