子コンポーネントに設定してあるメソッドを親から呼び出したいと思ってます。
逆の場合には、$emitを使えばいいと思うのですが、親から子のメソッドを呼ぶにはどうすればいいのでしょうか?または、そもそもそういったことはすべきではないのでしょうか?よろしくお願いします。
気になる質問をクリップする
クリップした質問は、後からいつでもMYページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。

回答3件
0
小規模なものの場合は、this.$refs.foo.bar()
のように$refsで子コンポーネントのメソッドを呼び出すことも可能です。
が、コンポーネント間の直接のデータの参照は推奨されていません。
しかし、はっきりと定義されたインタフェースを経由して、親と子を可能な限り分離されたものとしておくこともまた、とても大切です。これにより、各々のコンポーネントのコードは比較的独立した状態で書かれ判断されることが保証されます。それゆえ、コンポーネントを、よりメンテナンス可能で潜在的に再利用可能にできます
したがって、基本的には
- 子から親は $emit
- 親から子は props
でデータを受け渡すのが良いかもしれません。
ただ、propsでは直接的に子コンポーネントのメソッドを呼び出すことはできません。
したがって、コンポーネント間の処理の連携には下記のようにEventBusを使う手段があります。
var EventBus = new Vue() Object.defineProperties(Vue.prototype, { $bus: { get() { return EventBus } } } let ComponentY = Vue.extend({ mounted(){ this.$bus.$on('onMountedX', () => { console.log('onMountedX') }) } }) let ComponentX = Vue.extend({ mounted(){ this.$bus.$emit('onMountedX') } components: [ComponentY] })
ただし、より大規模なものを作る場合はvuexみたいなものでステート管理を行うのが良いです。
投稿2017/08/25 13:29
編集2017/08/25 13:54総合スコア17
0
子コンポーネントにref属性で参照できるようにしておくと、親から子のメソッドを呼び出せます
以下サンプルプログラムです。
親コンポーネントのApp.vueのtestメソッドで、$refsを使って子コンポーネントのTest.vueのメソッドを呼び出しています。
App.vue
<template> <div id="app"> <test ref="test"></test> <button @click="test">test</button> </div> </template> <script> import Test from "./Test.vue" export default { methods:{ test(){ console.log("parentMethod") this.$refs.test.childMethod() }, }, components:{Test} } </script>
Test.vue
<template> <p>test</p> </template> <script> export default { methods:{ childMethod(){ console.log("childMethod") } } } </script>
投稿2017/08/20 12:53
総合スコア4106
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
あなたの回答
tips
太字
斜体
打ち消し線
見出し
引用テキストの挿入
コードの挿入
リンクの挿入
リストの挿入
番号リストの挿入
表の挿入
水平線の挿入
プレビュー
質問の解決につながる回答をしましょう。 サンプルコードなど、より具体的な説明があると質問者の理解の助けになります。 また、読む側のことを考えた、分かりやすい文章を心がけましょう。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。