亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

vue 組件之間事件觸發($emit)與event Bus($on)的用法說明

瀏覽:3日期:2022-12-25 09:42:15

組件之間事件觸發

之前使用組件,并不是很頻繁,是水平的問題,目前工作中,公司大佬帶著我手寫過一個組件,再此很感謝他的指導。目前簡單的組件已經有了自己的邏輯思維,正在從低級碼農向中級碼農蛻變。廢話不多說。上圖看看組件情況。

vue 組件之間事件觸發($emit)與event Bus($on)的用法說明

新增按鈕組件:

vue 組件之間事件觸發($emit)與event Bus($on)的用法說明

操作按鈕組合組件:

vue 組件之間事件觸發($emit)與event Bus($on)的用法說明

此時有個需求就是,無論是哪個按鈕,如果改變了列表中的數據,列表需要實時更新數據。

此時就需要用到組件間的事件觸發。

父子組件之間事件觸發可以使用$emit

$emit的使用方法如下:

在子組件中,寫一個click點擊事件。比如:

cancelCU() { this.dialogVisible = false; this.$emit(’closeAdd’)}

然后在父組件中子組件上,添加一個 @closeAdd='closeAddClick',closeAddClick函數就是執行了。

新增按鈕可以使用這種方式。但是操作按鈕組合中的組件,就屬于孫子組件了,孫子組件執行click事件,列表數據需要刷新,此時通過孫子組件觸發父組件事件,父組件觸發爺爺組件,就比較麻煩了,此時可以通過event bus實現跨組件的事件觸發了。

具體使用方法如下:

第一步:

新建一個js文件,來創建出我們的eventBus,我們把它命名為bus.js

內容如下:

import Vue from ’vue’;

export default new Vue();

第二步:

在孫子組件和爺爺組件中,都需要引入這個bus.js

import Bus from ’common/js/bus.js’;

孫子組件執行方法如下:

addCart(event) { //如果傳遞參數的話,可以如下這樣寫 Bus.$emit(’getTarget’, event.target); //如果不傳遞參數可以如下; Bus.$emit(’getTarget’);}

這里我們在click組件中每次點擊,都會在bus中觸發這個名為’getTarget’的事件,并將點擊事件的event.target順著事件傳遞出去。

接著,我們要在show組件中的created()鉤子中調用bus監聽這個事件,并接收參數:

created() { //如果傳遞參數的話,爺爺組件需要這樣接收 Bus.$on(’getTarget’, target => { console.log(target); }); //如果不傳遞參數的話,則可以如下處理 Bus.$on(’getTarget’,()=>{ //此處執行對應的函數操作 })}

這樣,在每次click組件的點擊事件中,就會把event.target傳遞到show中,并console出來。

所以eventBus的使用還是非常便捷的,但是如果是中大型項目,通信比較復雜,還是建議大家直接使用vuex。

補充知識:vue 2 使用Bus.js進行兄弟(非父子)組件通信 簡單案例

vue2中廢棄了$dispatch和$broadcast廣播和分發事件的方法。父子組件中可以用props和$emit()。如何實現非父子組件間的通信,可以通過實例一個vue實例Bus作為媒介,要相互通信的兄弟組件之中,都引入Bus,之后通過分別調用Bus事件觸發和監聽來實現組件之間的通信和參數傳遞。

首先需要在任意地方添加一個bus.js

vue 組件之間事件觸發($emit)與event Bus($on)的用法說明

在bus.js里面 寫入下面信息

import Vue from ’vue’

export default new Vue;

vue 組件之間事件觸發($emit)與event Bus($on)的用法說明

在需要通信的組件都引入Bus.js

如果你的bus.js是自定義一個bus的文件那from后面就改成你的所放的位置

import Bus from ’./bus.js’

vue 組件之間事件觸發($emit)與event Bus($on)的用法說明

接下來就是要組件通信了

添加一個 觸發 #emit的事件按鈕

<template> <div id='emit'> <button @click='bus'>按鈕</button> </div> </template> import Bus from ’./bus.js’ export default { data() { return { message: ’’' } },methods: { bus () { Bus.$emit(’msg’, ’我要傳給兄弟組件們,你收到沒有’) } }}

打開要和$emit通信的另外一個組件 添加

vue 組件之間事件觸發($emit)與event Bus($on)的用法說明

在鉤子函數中監聽msg事件

<template> <div id='on'> <p>{{message}}</p> </div></template>import Bus from ’./bus.js’export default { data() { return { message: ’’ } }, mounted() {let self = this Bus.$on(’msg’, (e) => { self.message = e console.log(`傳來的數據是:${e}`) }) } }

最后p會顯示來自$emit傳來的信息

以上這篇vue 組件之間事件觸發($emit)與event Bus($on)的用法說明就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 亚洲视频一区二区 | 国产美女一区精品福利视频 | 鲁丝片一区二区三区免费 | 1024人成网色www| 欧美 日韩 国产 成人 在线观看 | 国产vr一区二区在线观看 | 请以你的名字呼唤我免费观看 | 福利入口在线观看 | 欧美成人亚洲高清在线观看 | 最新国产中文字幕 | 日本亚洲精品色婷婷在线影院 | 国产精品嫩草影院免费看 | 久久996re热这里只有精品 | 欧美成人毛片在线视频 | 拍拍拍拍拍拍拍无挡大全免费 | 日韩中文字幕免费版 | 国产成人亚洲毛片 | 影音先锋5566手机在线播放 | a级片在线看| 欧美午夜一艳片欧美精品 | 国内精品综合九九久久精品 | 一 级 黄 色生活片 一 级 黄 色蝶 片 | 黄色a级免费 | 国产aaaaa一级毛片 | 亚洲精品一区二区三区r | 精品国产自在现线看久久 | 青青在线国产 | 欧美日韩在线播放 | 大片免费观看入口 | 国产精品视频一区麻豆 | 特黄十八岁大片 | 丝袜网站在线观看 | 国产观看精品一区二区三区 | 国产欧美日韩视频在线观看一区二区 | 亚洲一区二区三区四 | 一级黄色a视频 | 国产成a人亚洲精v品久久网 | 国产原创自拍 | 日本精品久久久久久久 | 97久久久久 | 国产大片在线播放 |