【Flutter】EventBus简述

EventBus可以实现组件之间的消息通知,这里是讲述其简单应用(点击+- 按钮操作数据)。

1.添加依赖

2.添加数据总线(因为我看过几篇文章说过数据总线声明一个即可,所以我直接证明在main里面了)

3.声明数据总线分类

4.监听事件

5.声明要提交消息的控件



import 'package:flutter/material.dart';
import 'package:flutterdemo0507/eventBusType.dart';
import 'package:flutterdemo0507/main.dart';

class W1 extends StatefulWidget {
  @override
  _W1State createState() => _W1State();
}

class _W1State extends State<W1> with SingleTickerProviderStateMixin {
  AnimationController _controller;

  @override
  void initState() {
    _controller = AnimationController(vsync: this);
    super.initState();
  }

  @override
  void dispose() {
    _controller.dispose();
    super.dispose();
  }

  @override
  Widget build(BuildContext context) {
    return Row(
      children: <Widget>[
        RaisedButton(child: Text('+'),onPressed: (){
          eventBus.fire(EventBus1('+'));
        }),
        RaisedButton(child: Text('-'),onPressed: (){
          eventBus.fire(EventBus1('-'));
        })
      ],
    );
  }
}

6.主页面显示

class MyHomePage extends StatefulWidget {
  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State<MyHomePage> {
  int _count1 = 0;
  int _count2 = 0;

  @override
  void initState() {
    super.initState();
    eventBus.on<EventBus1>().listen((event) {
      switch(event.data){
        case '+':
          _count1++;
          break;
        case '-':
          _count1--;
          break;
      }
      setState(() {
      });
    });
    eventBus.on<EventBus2>().listen((event) {
      switch(event.data){
        case '+':
          _count2++;
          break;
        case '-':
          _count2--;
          break;
      }
      setState(() {
      });
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('demo'),
      ),
      body: Column(
        crossAxisAlignment: CrossAxisAlignment.start,
        children: <Widget>[Text('$_count1'), W1(), Text('$_count2'), W2()],
      ),
    );
  }
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值