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

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

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

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

Q&A

解決済

1回答

3622閲覧

vueファイル内のdataを外部から参照したい

funmas

総合スコア31

Vue.js

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

0グッド

1クリップ

投稿2018/10/16 07:41

前提・実現したいこと

foo.vueの中のdataを
bar.vueから参照したい

該当のソースコード

foo

1//foo.vue 2<template> 3 <div> 4 <form @submit.prevent="testFoo"> 5 <input type="submit" value="fooButton"> 6 </form> 7 </div> 8</template> 9 10<script> 11export default { 12 data() { 13 return { 14 msg: "fooですよ" 15 }; 16 }, 17 methods: { 18 testFoo: function() { 19 console.log("--testFoo"); 20 console.log(this.msg) 21 } 22 } 23}; 24</script>

bar

1//bar.vue 2<template> 3 <div> 4 <form @submit.prevent="testBar"> 5 <input type="submit" value="barButton"> 6 </form> 7 </div> 8</template> 9 10<script> 11import fooB from "@/components/foo.vue"; 12export default { 13 methods: { 14 testBar: function() { 15 console.log("--testBar"); 16 fooB.methods.testFoo(); 17 } 18 } 19}; 20</script>

試したこと

上記componentsをそれぞれ表示し、
実行した際、

console

1foo.vue --testFoo 2foo.vue fooですよ 3bar.vue --testBar 4foo.vue --testFoo 5foo.vue undefined

となり、testBarメソッドより、
testFooのthis.msgにアクセスできていないようです。
アクセスが可能になれば、returnでBarからFooの値を取得したいと考えています。

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

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

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

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

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

guest

回答1

0

ベストアンサー

別々のコンポネントの間で値を共有するためには
大きく分けるとEventBusを利用するパターンと、Pluginを利用するパターン、propsなどを使えます。それぞれ状況により役目が違います。

この場合、他のコンポネントのメソッドを使うのだと判断し、EventBusを使います。

わかりやすく出来てるページはここでした。
https://medium.com/@andrejsabrickis/https-medium-com-andrejsabrickis-create-simple-eventbus-to-communicate-between-vue-js-components-cdc11cd59860

やるべきことはこうなります。

  1. EventBusを宣言
  2. ボタンを押すページ(bar)からEventBusのemit()を利用して呼び出したいイベントの名前を設定(キーです)
  3. データを持って来たいページから(foo)EventBusのon()を利用し、実行したいイベントを紐づけする

jsfiddle(old) : https://jsfiddle.net/yeondev/bq0fpL8j/

jsfiddle(new) : https://jsfiddle.net/yeondev/bq0fpL8j/9/

■ 補足

上記のパターンは、AからBにデータを送ったり、トリガーを引いたりする仕組みです。
Aから変化を与えたBのデータを、Aからまた取得するにはデータをピンポンするようにやり取りする方法があります。

typescript

1// main.js 2// EventBusを宣言しましょう 3Vue.prototype.$EventBus = new Vue()

typescript

1// foo.vue 2<template> 3 <div> 4 <form @submit.prevent="testFoo"> 5 <input type="submit" value="fooButton"> => {{ msg }} 6 </form> 7 </div> 8</template> 9 10<script> 11 12export default { 13 data () { 14 return { 15 msg: 'default fooですよ' 16 } 17 }, 18 methods: { 19 testFoo: function () { 20 console.log('順番3.Foo::testFoo() 開始') 21 console.log('順番3-1.Foo::testFoo() 変化する前のメッセージ=> ', this.msg) 22 this.msg = 'updated fooですよ' 23 console.log('順番3-2.Foo::testFoo() 変化する後のメッセージ=> ', this.msg) 24 console.log('順番3-3.Foo::testFoo() リターンせずMsgだけ変換したまま終了') 25 } 26 }, 27 created () { 28 this.$EventBus.$on('callTestFoo', () => { 29 console.log('順番2.Foo::EventBus:EventBus始動、Fooから何かの処理を行う(この場合testFoo)') 30 this.testFoo() // msgに何か変化を与えたい場合に使う関数 31 console.log('順番4.Foo::EventBus:msgをパラメータとしてBarの関数を呼び出す') 32 this.$EventBus.$emit('callTestBar', this.msg) // barにmsgを送る 33 }) 34 } 35} 36</script> 37 38

Typescript

1//bar.vue 2<template> 3 <div> 4 <foo></foo> 5 <form @submit.prevent="testBar"> 6 <input type="submit" value="barButton"> => {{ barMsg }} 7 </form> 8 </div> 9</template> 10 11<script> 12import bar from '@/components/bar' 13import foo from '@/components/foo' 14 15export default { 16 data () { 17 return { 18 barMsg: 'default barですよ' 19 } 20 }, 21 components: { 22 foo, 23 bar 24 }, 25 methods: { 26 getValueFromFoo: function (value) { 27 console.log('順番6.Bar::getValueFrom:パラメータを受け取る') 28 this.barMsg = value 29 }, 30 testBar: function () { 31 console.log('順番1.Bar::testBar:パラメータなしでFooの関数を呼び出す') 32 this.$EventBus.$emit('callTestFoo') 33 // fooB.methods.testFoo() 34 } 35 }, 36 created () { 37 this.$EventBus.$on('callTestBar', (parameterFromFoo) => { 38 console.log('順番5.Bar::EventBus:EventBus始動、getValueFromFoo関数を呼び出す。書かれてないがFooから貰ったパラメータが入ってる(getValueFromFoo(msg)みたいに)') 39 this.getValueFromFoo(parameterFromFoo) 40 }) // fooからmsgを貰い、getValueFromFooにパラメータとして渡す 41 } 42} 43</script>

投稿2018/10/16 08:44

編集2018/10/16 10:25
yeondev

総合スコア198

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

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

funmas

2018/10/16 10:05 編集

回答大変ありがとうございます。 自分で思っていたよりも複雑な問題で、非常に助かっております。 記載していただいた内容で無事に、例であげたプログラムを動作することができました。 しかし恥ずかしながら、参照さえ出来てしまえば、 returnで値が返せるものと思っていましたが、簡単なものではなかったようです。 //----------------------------- //foo.vue testFoo: function() { console.log("--testFoo"); console.log(this.msg) return this.msg } //----------------------------- //bar.vue console.log(this.$EventBus.$emit('callTestFoo')) // 追加 //----------------------------- // console foo.vue --testFoo foo.vue fooですよ bar.vue --testBar foo.vue --testFoo foo.vue fooですよ bar.vue Vue {_... 上記でテストしましたが、msgをBar側で表示することができませんでした。 もしよろしければ、値の引っ張り方をご教示願えないでしょうか。
yeondev

2018/10/16 10:25

なんかめちゃくちゃな形になりましたが、更新した返答をご確認ください。
funmas

2018/10/17 02:33

大変助かりました!! 幾度も対応していただきありがとうございます。 今までアローの意味がわからず、可読性という意味でfunctionで記述してしまい、 thisにアクセスできず、泥沼にはまっていましたが、そこはなんとか自力で解決できました (参考:https://qiita.com/mejileben/items/69e5facdb60781927929) このピンポン形式で無事に値を取得することができました。 処理の順番まで懇切に説明していただきありがとうございます。 これからも勉強を進めていきたいと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問