栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

Flutter跨组件传递事件

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Flutter跨组件传递事件


步骤 1. 引入第三方库

在 pubspec.yaml 引入 event_bus: ^1.1.1

2. 定义在组件之间传递的对象
class UserInfo {
  String nickname;
  int level;
	
  UserInfo(this.nickname, this.level);
}
3. 创建全局的EventBus对象

final eventBus = EventBus();

4. 在某个widget发出事件
FlatButton(
child: Text("Testbutton", style: TextStyle(color: Colors.white)),
color: Colors.orange, // 按钮的颜色

onPressed: () {
  final info = UserInfo("why", 18);
  eventBus.fire(info);
},
     ),
5. 在另一个widget监听事件
  @override
  void initState() {
    super.initState();

    eventBus.on().listen((data) {
      setState(() {
 message = "${data.nickname}-${data.level}";
      });
    });
  }
完整代码
import 'package:flutter/material.dart';
import 'package:event_bus/event_bus.dart';

void main() {
  runApp(MyApp());
}

class UserInfo {
  String nickname;
  int level;

  UserInfo(this.nickname, this.level);
}

class MyApp extends StatelessWidget {
  // This widget is the root of your application.
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Demo',
      theme: ThemeData(
 primarySwatch: Colors.blue,
      ),
      home: MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatefulWidget {
  MyHomePage({Key key, this.title}) : super(key: key);

  final String title;

  @override
  _MyHomePageState createState() => _MyHomePageState();
}

class _MyHomePageState extends State {
  final eventBus = EventBus();

  String message = "Hello Coderwhy";

  @override
  void initState() {
    super.initState();

    eventBus.on().listen((data) {
      setState(() {
 message = "${data.nickname}-${data.level}";
      });
    });
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
 title: Text(widget.title),
      ),
      body: Center(
 child: Column(
   mainAxisAlignment: MainAxisAlignment.center,
   children: [
     Text(
message,
style: Theme.of(context).textTheme.headline4,
     ),
     FlatButton(
child: Text("Testbutton", style: TextStyle(color: Colors.white)),
color: Colors.orange, // 按钮的颜色

onPressed: () {
  final info = UserInfo("why", 18);
  eventBus.fire(info);
},
     ),
   ],
 ),
      ),
    );
  }
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/241940.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号