EventBus兄弟コンポーネント通信の詳細説明

php中世界最好的语言
リリース: 2018-04-17 09:25:34
オリジナル
1975 人が閲覧しました

今回は、eventBus 兄弟コンポーネント通信について詳しく説明します。eventBus 兄弟コンポーネント通信の 注意事項 について、実際のケースを見てみましょう。

vue1.0 では、コンポーネント間の通信は主に、親チェーンに沿って にアップロードする vm.$dispatch と、下向きに vm.$ブロードキャスト することによって実現されます。ただし、vue2.0ではこの使い方は廃止されました。

vuex を追加すると、コンポーネント間の通信がより明確になります。中規模および大規模なプロジェクトの場合は、最初から vuex の使用を計画することが賢明です。

ただし、一部の小規模プロジェクトや、作成の途中で $.broadcast と $dispatch が vue2.0 で使用できないことに気付いた私のような人にとっては、より便利なソリューションが必要です。すると、eventBusの役割が反映されます。

主な実際的なアプローチは、相互に通信したい兄弟コンポーネント間に新しい vue インスタンスを導入し、このインスタンスの

event トリガーとモニタリングをそれぞれ呼び出すことで通信とパラメーター転送を実現することです。

簡単な例を次に示します:

たとえば、ここには 3 つのコンポーネント、

main.vue、click.vue、および show.vue があります。 click と show は親コンポーネント main の下にある兄弟コンポーネントであり、click は v-for を介して親コンポーネント内の複数のリスト項目をトラバースします。ここで実装する必要があるのは、click コンポーネントで click イベントがトリガーされた後、show コンポーネントがどの DOM 要素がクリックされたかをコンソールすることです。

まず、クリックコンポーネントにクリックイベントを追加します

<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 サイトの他の関連記事に注目してください。

推奨読書:

Vueの配列とオブジェクトの割り当ての問題

ブートストラップとVueの操作ユーザー情報の追加と削除

Yuansheng JSが非同期ファイルアップロードを実装する方法

以上がEventBus兄弟コンポーネント通信の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート