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

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

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

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

Nuxt.js

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

Q&A

解決済

2回答

635閲覧

nuxtでvueのv-modelでのフォーム入力バインディングが効かない

you88

総合スコア147

Vue.js

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

Nuxt.js

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

0グッド

0クリップ

投稿2019/03/21 01:52

nuxtのpages/index.vueで下記の実装をしたのですがうまく値がリアルタイムでバインディングされません。。。

<input v-model="message" placeholder="edit me"> <p>Message is: {{ message }}</p>

なぜかコード上でmessageを変更して保存したときだけききます。event設定しなくてもv-modelはきくと思っていたのですがイベントを設定しないとうまく発火しないのかなとも思ったんですが下記のvueのドキュメントだとそういうわけでもなさそうだなと思っています。

https://jp.vuejs.org/v2/guide/forms.html

nuxt上でうまくinputに入力したmessageをリアルタイムにバインディングする方法はないでしょうか?

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

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

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

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

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

FeLvi_zzz

2019/03/21 02:16 編集

2点質問したいことがあります。 ・コンポーネントの中のdata内でmessageは初期化していますか? ・日本語など変換が必要な言語は確定するまで反映されませんが、リアルタイムにバインディングする対象というのは英語のことでしょうか? よろしくお願いします。
you88

2019/03/21 07:35

>・コンポーネントの中のdata内でmessageは初期化していますか? →すみません、初期化というのはどうやったらできるでしょうか? ・日本語など変換が必要な言語は確定するまで反映されませんが、リアルタイムにバインディングする対象というのは英語のことでしょうか? →日本語を確定したときに反映されるようにしたいです
guest

回答2

0

ベストアンサー

ES6のアロー関数はfunction(){ }とthisが指すものが違うので、

vue

1data(){ 2 message: '' 3}

の形で宣言してください。

ちなみにオブジェクト内の

vue

1data(){ 2 message: '' 3}

はES5で書くと、

vue

1data: function() { 2 message: '' 3}

となります。

コメントで

vue

1export default { 2 var appform = new Vue({ 3 el: '#appform', 4 data: () => ({ 5 message: '' 6 }) 7 }) 8}

と書かれていますが、.vueファイルであれば

vue

1export default { 2 data() { 3 message: '' 4}

と書く必要があり、新たにVueインスタンスを作成する必要はありません。

投稿2019/03/21 09:57

FeLvi_zzz

総合スコア124

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

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

you88

2019/03/21 13:52

できました!ありがとうございます!また別の質問になってしまうのですがvueの記述をnuxtでする場合、componentのelの宣言は必要なく、全文がその対象になるんでしょうか?(vueだとelで命名したid名の中で記述した動作ができると思うのですが)
FeLvi_zzz

2019/03/21 14:04

お役に立てたようで何よりです。 Nuxtのpageフォルダ以下のvueファイルはそれぞれが一つのコンポーネントなので、ファイル内のtemplate全文が対象になります。
you88

2019/03/21 14:07

なるほど!ありがとうございました!
guest

0

vue

1<template> 2 <div> 3 <input 4 v-model="message" 5 placeholder="edit me" 6 > 7 <p>Message is: {{ message }}</p> 8 </div> 9</template> 10 11<script> 12export default { 13 data() { 14 return { 15 message: '' 16 } 17 } 18} 19</script>

index.vueの全体像です。
template内で使う変数は、使用する変数を含んだオブジェクトをdata関数の返り値として設定しておく必要があります。

投稿2019/03/21 09:33

編集2019/03/21 09:38
FeLvi_zzz

総合スコア124

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

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

you88

2019/03/21 09:43

export default { var appform = new Vue({ el: '#appform', data: () => ({ message: '' }) }) } ありがとうございます!こういった形で宣言したのですが反映されず。。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問