Flutter?EventBus事件總線(xiàn)的應(yīng)用詳解
前言
flutter項(xiàng)目中,有許多可以實(shí)現(xiàn)跨組件通訊的方案,其中包括InheritedWidget,Notification,EventBus等。本文主要探討的是EventBus事件總線(xiàn)實(shí)現(xiàn)跨組件通訊的方法。
EventBus的簡(jiǎn)介
EventBus
的核心是基于Streams
。它允許偵聽(tīng)器訂閱事件并允許發(fā)布者觸發(fā)事件,使得不同組件的數(shù)據(jù)不需要一層層傳遞,可以直接通過(guò)EventBus
實(shí)現(xiàn)跨組件通訊。
EventBus
最主要是通過(guò)觸發(fā)事件和監(jiān)聽(tīng)事件兩項(xiàng)操作來(lái)實(shí)現(xiàn)不同頁(yè)面的跨層訪(fǎng)問(wèn)。觸發(fā)事件是通過(guò)fire(event)方法進(jìn)行,監(jiān)聽(tīng)事件則是通過(guò)on<T>()方法進(jìn)行的,其中泛型可以傳入指定類(lèi)型,事件總線(xiàn)將進(jìn)行針對(duì)性監(jiān)聽(tīng),如果泛型傳值為空,則默認(rèn)監(jiān)聽(tīng)所有類(lèi)型的事件:
void fire(event) { streamController.add(event); }
Stream<T> on<T>() { if (T == dynamic) { return streamController.stream as Stream<T>; } else { return streamController.stream.where((event) => event is T).cast<T>(); } }
EventBus的實(shí)際應(yīng)用
1、在pubspec.yaml
文件中引用eventBus事件總線(xiàn)依賴(lài);
2、創(chuàng)建一個(gè)全局的EventBus
實(shí)例;
3、使用fire(event)
方法在事件總線(xiàn)上觸發(fā)一個(gè)新事件(觸發(fā)事件);
4、為事件總線(xiàn)注冊(cè)一個(gè)監(jiān)聽(tīng)器(監(jiān)聽(tīng)事件);
5、取消EventBus事件訂閱,防止內(nèi)存泄漏。
// 1、在pubspec.yaml文件中引用eventBus事件總線(xiàn)依賴(lài); dependencies: event_bus: ^2.0.0
// 2、創(chuàng)建一個(gè)全局的EventBus實(shí)例; EventBus myEventBus = EventBus();
// 3、使用fire(event)方法在事件總線(xiàn)上觸發(fā)一個(gè)新事件(觸發(fā)事件); Center( child: ElevatedButton( onPressed: () { myEventBus.fire('通過(guò)EventBus觸發(fā)事件'); }, child: Text('觸發(fā)事件'), ), )
var getData; @override void initState() { // TODO: implement initState super.initState(); // 4、為事件總線(xiàn)注冊(cè)一個(gè)監(jiān)聽(tīng)器(監(jiān)聽(tīng)事件); getData = myEventBus.on().listen((event) { print(event); }); } @override void dispose() { // TODO: implement dispose super.dispose(); // 5、取消EventBus事件訂閱,防止內(nèi)存泄漏。 getData.cancel(); }
總結(jié)
EventBus
遵循的是發(fā)布/訂閱模式,能夠通過(guò)事件的觸發(fā)和監(jiān)聽(tīng)操作,有效實(shí)現(xiàn)跨組件通訊的功能。
以上就是Flutter EventBus事件總線(xiàn)的應(yīng)用詳解的詳細(xì)內(nèi)容,更多關(guān)于Flutter EventBus事件總線(xiàn)的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Android如何自定義View實(shí)現(xiàn)橫向的雙水波紋進(jìn)度條
最近有個(gè)需求需要實(shí)現(xiàn)自定義加載進(jìn)度條,于是深入研究了一下,這篇文章主要給大家介紹了關(guān)于Android如何自定義View實(shí)現(xiàn)橫向的雙水波紋進(jìn)度條的相關(guān)資料,需要的朋友可以參考下2021-11-11Android實(shí)現(xiàn)簡(jiǎn)易計(jì)算功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)簡(jiǎn)易計(jì)算功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06Android 實(shí)現(xiàn)密碼輸入框動(dòng)態(tài)明文/密文切換顯示效果
在項(xiàng)目中遇到需要提供給用戶(hù)一個(gè)密碼輸入框明文/密文切換顯示的需求,今天小編借腳本之家平臺(tái)給大家分享下Android 實(shí)現(xiàn)密碼輸入框動(dòng)態(tài)明文/密文切換顯示效果,需要的朋友參考下2017-01-01Android基于ibeacon實(shí)現(xiàn)藍(lán)牙考勤功能
這篇文章主要為大家詳細(xì)介紹了Android基于ibeacon實(shí)現(xiàn)藍(lán)牙考勤功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-10-10Android?Settings?跳轉(zhuǎn)流程方法詳解
這篇文章主要為大家介紹了Android?Settings跳轉(zhuǎn)流程方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07Android開(kāi)發(fā)之HttpClient異步請(qǐng)求數(shù)據(jù)的方法詳解【附demo源碼下載】
這篇文章主要介紹了Android開(kāi)發(fā)之HttpClient異步請(qǐng)求數(shù)據(jù)的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了Android HttpClient異步請(qǐng)求數(shù)據(jù)的相關(guān)操作技巧,并附帶完整demo源碼供讀者下載參考,需要的朋友可以參考下2017-11-11