ホームページ >ウェブフロントエンド >jsチュートリアル >EventBus兄弟コンポーネント通信の詳細説明
今回は、eventBus 兄弟コンポーネント通信について詳しく説明します。eventBus 兄弟コンポーネント通信の 注意事項 について、実際のケースを見てみましょう。
vue1.0 では、コンポーネント間の通信は主に、親チェーンに沿って にアップロードする vm.$dispatch と、下向きに vm.$ブロードキャスト することによって実現されます。ただし、vue2.0ではこの使い方は廃止されました。
vuex を追加すると、コンポーネント間の通信がより明確になります。中規模および大規模なプロジェクトの場合は、最初から vuex の使用を計画することが賢明です。 ただし、一部の小規模プロジェクトや、作成の途中で $.broadcast と $dispatch が vue2.0 で使用できないことに気付いた私のような人にとっては、より便利なソリューションが必要です。すると、eventBusの役割が反映されます。 主な実際的なアプローチは、相互に通信したい兄弟コンポーネント間に新しい vue インスタンスを導入し、このインスタンスのevent トリガーとモニタリングをそれぞれ呼び出すことで通信とパラメーター転送を実現することです。
簡単な例を次に示します: たとえば、ここには 3 つのコンポーネント、 まず、クリックコンポーネントにクリックイベントを追加します<p class="click" @click.stop.prevent="doClick($event)"></p>doClick() メソッドで show コンポーネントとの通信を実装するには、eventBus を作成するための新しい js ファイルを作成する必要があります。これに、bus.js
import Vue from 'vue'; export default new Vue();という名前を付けます。 このようにして、新しい vue インスタンスを作成します。次に、それを click コンポーネントと show コンポーネントにインポートします。
りー
次に、doClick メソッドでイベントをトリガーします:import Bus from 'common/js/bus.js';ここで、クリック コンポーネントをクリックするたびに、「getTarget」という名前のイベントがバス内でトリガーされ、クリック イベントのevent.targetがイベントに沿って渡されます。 次に、show コンポーネントの created() フックでバスを呼び出して、このイベントをリッスンしてパラメータを受け取る必要があります:
methods: { addCart(event) { Bus.$emit('getTarget', event.target); } }このようにして、クリック コンポーネントの各クリック イベントで、event.target がショーに渡されてコンソール化されます。 そのため、eventBus の使用は依然として非常に便利ですが、中規模から大規模なプロジェクトで通信がより複雑な場合は、vuex を直接使用することをお勧めします。 この記事の事例を読んだ後、あなたはその方法を習得したと思います。さらに興味深い情報については、php 中国語 Web サイトの他の関連記事に注目してください。 推奨読書:
Yuansheng JSが非同期ファイルアップロードを実装する方法
以上がEventBus兄弟コンポーネント通信の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。