Bloc流如何被填充?
创始人
2024-12-22 21:30:27
0

在Flutter中,可以使用BlocBuilderStreamBuilder来监听流并更新UI。以下是一个使用BlocBuilder的示例:

首先,创建一个Bloc类,该类负责管理业务逻辑和状态:

import 'dart:async';

class MyBloc {
  final _controller = StreamController();

  Stream get stream => _controller.stream;

  void fetchData() {
    // 模拟异步获取数据
    Future.delayed(Duration(seconds: 2), () {
      _controller.sink.add('Data from stream');
    });
  }

  void dispose() {
    _controller.close();
  }
}

然后,在你的UI层使用BlocBuilder来监听流并更新UI:

import 'package:flutter/material.dart';

class MyWidget extends StatelessWidget {
  final MyBloc bloc = MyBloc();

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Bloc Example'),
      ),
      body: Center(
        child: BlocBuilder(
          bloc: bloc,
          builder: (BuildContext context, String data) {
            if (data == null) {
              return CircularProgressIndicator();
            } else {
              return Text(data);
            }
          },
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: () {
          bloc.fetchData();
        },
        child: Icon(Icons.refresh),
      ),
    );
  }

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

在上面的示例中,MyBloc类维护了一个StreamController,用于发布数据流。fetchData方法模拟了一个异步操作并在完成后使用_controller.sink.add将数据添加到流中。

在UI层,我们使用BlocBuilder来监听流并根据数据的变化来更新UI。在builder回调中,我们根据数据是否为null来决定显示进度指示器还是显示数据。

最后,我们在floatingActionButton中调用bloc.fetchData方法来触发数据的获取。

需要注意的是,在组件销毁时,我们需要调用bloc.dispose来关闭流和释放资源,以避免内存泄漏。

相关内容

热门资讯

一分钟带你了解!微扑克必胜技巧... 一分钟带你了解!微扑克必胜技巧,微扑克有挂么(微扑克)都是真的有挂(有挂解惑)-哔哩哔哩;运微扑克必...
重大通报!微扑克辅助工具怎么下... 重大通报!微扑克辅助工具怎么下载,微扑克透牌(微扑克)原来存在有挂(有挂规律)-哔哩哔哩;1、每一步...
交流学习经验!微扑克辅助插件挂... 交流学习经验!微扑克辅助插件挂,微扑克ai机器人(微扑克)竟然真的有挂(的确有挂)-哔哩哔哩交流学习...
推荐十款!微扑克ai代打,微扑... 推荐十款!微扑克ai代打,微扑克ai机器人(微扑克)总是是有挂(确实有挂)-哔哩哔哩1、任何微扑克a...
分享给玩家!微扑克有辅助透视,... 分享给玩家!微扑克有辅助透视,微扑克透牌(微扑克)都是真的是有挂(确实有挂)-哔哩哔哩该软件可以轻松...
热门推荐!微扑克辅助测试,微扑... 热门推荐!微扑克辅助测试,微扑克有挂么(微扑克)都是存在有挂(有挂教学)-哔哩哔哩;微扑克辅助测试是...
如何分辨真伪!微扑克必胜技巧,... 如何分辨真伪!微扑克必胜技巧,微扑克ai机器人(微扑克)竟然是有挂(有挂方针)-哔哩哔哩运微扑克必胜...
重大通报!微扑克德州专用辅助器... 重大通报!微扑克德州专用辅助器,微扑克如何让系统发好牌(微扑克)本来存在有挂(有挂猫腻)-哔哩哔哩小...
免费测试版!微扑克透牌真假的,... 免费测试版!微扑克透牌真假的,微扑克如何让系统发好牌(微扑克)原来是真的有挂(有挂技术)-哔哩哔哩;...
三分钟了解!微扑克辅助透视技能... 三分钟了解!微扑克辅助透视技能教程,微扑克有挂么(微扑克)真是存在有挂(有人有挂)-哔哩哔哩;1、每...