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

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

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

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

Q&A

解決済

3回答

38761閲覧

Vuejsで子コンポーネントのメソッドを親から呼びたい

atemu

総合スコア94

Vue.js

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

1グッド

2クリップ

投稿2017/08/20 08:12

子コンポーネントに設定してあるメソッドを親から呼び出したいと思ってます。

逆の場合には、$emitを使えばいいと思うのですが、親から子のメソッドを呼ぶにはどうすればいいのでしょうか?または、そもそもそういったことはすべきではないのでしょうか?よろしくお願いします。

kurocraft0312👍を押しています

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

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

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

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

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

guest

回答3

0

小規模なものの場合は、this.$refs.foo.bar() のように$refsで子コンポーネントのメソッドを呼び出すことも可能です。
が、コンポーネント間の直接のデータの参照は推奨されていません。

コンポーネント - Vue.js

しかし、はっきりと定義されたインタフェースを経由して、親と子を可能な限り分離されたものとしておくこともまた、とても大切です。これにより、各々のコンポーネントのコードは比較的独立した状態で書かれ判断されることが保証されます。それゆえ、コンポーネントを、よりメンテナンス可能で潜在的に再利用可能にできます

したがって、基本的には

  • 子から親は $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
pulse

総合スコア17

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

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

0

自己解決

refでやるのが良さそうです

複雑になる場合はvuexを使います

投稿2018/04/30 01:30

atemu

総合スコア94

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

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

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

aro10

総合スコア4106

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問