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来关闭流和释放资源,以避免内存泄漏。

相关内容

热门资讯

事发当天!上饶辅助设备出租,真... 事发当天!上饶辅助设备出租,真是是真的辅助工具(有挂头条)-哔哩哔哩上饶辅助设备出租脚本下载中分为三...
随着!菠萝神辅助器app,一直... 随着!菠萝神辅助器app,一直是有辅助平台(有挂教程)-哔哩哔哩1、很好的工具软件,可以解锁游戏的菠...
推出新举措!兴动海满辅助,一贯... 您好,兴动海满辅助这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很多玩家在...
做出回应!微乐贵阳捉鸡麻将挂软... 做出回应!微乐贵阳捉鸡麻将挂软件,果然真的是有辅助神器(有挂秘诀)-哔哩哔哩1、打开软件启动之后找到...
反观!九游破解辅助插件,都是真... 反观!九游破解辅助插件,都是真的有辅助神器(有挂秘籍)-哔哩哔哩九游破解辅助插件能透视中分为三种模型...
据文件显示!科米台州麻将辅助,... 据文件显示!科米台州麻将辅助,真是有挂辅助app(竟然有挂)-哔哩哔哩1、每一步都需要思考,不同水平...
今天上午!赣湘互娱挂,总是是有... 今天上午!赣湘互娱挂,总是是有辅助修改器(有挂详情)-哔哩哔哩1、在赣湘互娱挂插件功能辅助器技巧中,...
来临!广西友乐解码器辅助器,原... 来临!广西友乐解码器辅助器,原来真的是有辅助脚本(真的有挂)-哔哩哔哩1.广西友乐解码器辅助器 选牌...
来临!新天道辅助脚本,确实有挂... 来临!新天道辅助脚本,确实有挂辅助下载(有挂秘诀)-哔哩哔哩1、金币登录送、破产送、升级送、活动送。...
近期!青橙竞技卡五星辅助,好像... 近期!青橙竞技卡五星辅助,好像真的是有辅助脚本(竟然有挂)-哔哩哔哩1、用户打开应用后不用登录就可以...