当前位置:主页 > android教程 > Flutter EventBus事件总线

Flutter EventBus事件总线的应用详解

发布:2023-03-03 16:30:01 59


给寻找编程代码教程的朋友们精选了相关的编程文章,网友聂朗宁根据主题投稿了本篇教程内容,涉及到Flutter、EventBus事件总线、Flutter、EventBus、Flutter EventBus事件总线相关内容,已被935网友关注,如果对知识点想更进一步了解可以在下方电子资料中获取。

Flutter EventBus事件总线

前言

flutter项目中,有许多可以实现跨组件通讯的方案,其中包括InheritedWidget,Notification,EventBus等。本文主要探讨的是EventBus事件总线实现跨组件通讯的方法。

EventBus的简介

EventBus的核心是基于Streams。它允许侦听器订阅事件并允许发布者触发事件,使得不同组件的数据不需要一层层传递,可以直接通过EventBus实现跨组件通讯。

EventBus最主要是通过触发事件监听事件两项操作来实现不同页面的跨层访问。触发事件是通过fire(event)方法进行,监听事件则是通过on()方法进行的,其中泛型可以传入指定类型,事件总线将进行针对性监听,如果泛型传值为空,则默认监听所有类型的事件:

void fire(event) {
  streamController.add(event);
}
Stream on() {
  if (T == dynamic) {
    return streamController.stream as Stream;
  } else {
    return streamController.stream.where((event) => event is T).cast();
  }
}

EventBus的实际应用

1、在pubspec.yaml文件中引用eventBus事件总线依赖;

2、创建一个全局的EventBus实例;

3、使用fire(event)方法在事件总线上触发一个新事件(触发事件);

4、为事件总线注册一个监听器(监听事件);

5、取消EventBus事件订阅,防止内存泄漏。

// 1、在pubspec.yaml文件中引用eventBus事件总线依赖;
dependencies:
    event_bus: ^2.0.0
// 2、创建一个全局的EventBus实例;
EventBus myEventBus = EventBus();
// 3、使用fire(event)方法在事件总线上触发一个新事件(触发事件);
Center(
  child: ElevatedButton(
    onPressed: () {
      myEventBus.fire('通过EventBus触发事件');
    },
    child: Text('触发事件'),
  ),
)
var getData;
@override
void initState() {
  // TODO: implement initState
  super.initState();
  // 4、为事件总线注册一个监听器(监听事件);
  getData = myEventBus.on().listen((event) {
    print(event);
  });
}
@override
void dispose() {
  // TODO: implement dispose
  super.dispose();
  // 5、取消EventBus事件订阅,防止内存泄漏。
  getData.cancel();
}

总结

EventBus遵循的是发布/订阅模式,能够通过事件的触发和监听操作,有效实现跨组件通讯的功能。

以上就是Flutter EventBus事件总线的应用详解的详细内容,更多关于Flutter EventBus事件总线的资料请关注码农之家其它相关文章!


相关文章

  • Flutter StatefulBuilder实现局部刷新实例详解

    发布:2023-03-02

    这篇文章主要为大家介绍了Flutter StatefulBuilder实现局部刷新实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • flutter中使用流式布局示例详解

    发布:2023-03-12

    这篇文章主要为大家介绍了flutter中使用流式布局示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • Flutter实现矩形取色器的封装

    发布:2023-03-02

    这篇文章主要为大家详细介绍了Flutter实现矩形取色器的封装,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下


  • Flutter WillPopScope拦截返回事件原理示例详解

    发布:2023-03-11

    这篇文章主要为大家介绍了Flutter WillPopScope拦截返回事件原理示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • Flutter学习LogUtil封装与实现实例详解

    发布:2023-03-06

    这篇文章主要为大家介绍了Flutter学习LogUtil封装与实现实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪


  • Flutter组件实现进度指示器

    发布:2023-03-02

    这篇文章主要为大家详细介绍了Flutter组件实现进度指示器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下


  • Flutter实现下拉刷新和上拉加载更多

    发布:2023-03-02

    这篇文章主要为大家详细介绍了Flutter实现下拉刷新和上拉加载更多,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下


  • Android Flutter实现自定义下拉刷新组件

    发布:2023-03-02

    在Flutter开发中官方提供了多平台的下拉刷新组件供开发者使用。本文将改造一下这些组件,实现自定义的下拉刷新组件,感兴趣的可以了解一下


网友讨论