一个Flutter BLoC入门的简单 demo

通过一个非常简单的计数器示例来演示如何使用BLoC模式。这个计数器将有增加和减少两个功能。

步骤 1: 添加依赖

首先,确保你的Flutter项目中添加了flutter_bloc依赖。在你的pubspec.yaml文件中添加:

yaml 复制代码
dependencies:
  flutter_bloc: ^8.0.1 # 请检查最新版本
  flutter:
    sdk: flutter

然后运行flutter pub get来安装依赖。

步骤 2: 创建CounterEvent

创建一个counter_event.dart文件,这个文件将包含我们的事件类。对于计数器,我们将有两个事件:增加和减少。

dart 复制代码
abstract class CounterEvent {}

class CounterIncrementPressed extends CounterEvent {}

class CounterDecrementPressed extends CounterEvent {}

步骤 3: 创建CounterState

接着,创建一个counter_state.dart文件,这个文件将定义计数器的状态。

dart 复制代码
class CounterState {
  final int counterValue;

  CounterState({required this.counterValue});
}

步骤 4: 创建CounterBloc

现在,创建counter_bloc.dart,这是核心部分,它将处理事件并更新状态。

dart 复制代码
import 'package:flutter_bloc/flutter_bloc.dart';
import 'counter_event.dart';
import 'counter_state.dart';

class CounterBloc extends Bloc<CounterEvent, CounterState> {
  CounterBloc() : super(CounterState(counterValue: 0)) {
    on<CounterIncrementPressed>((event, emit) {
      emit(CounterState(counterValue: state.counterValue + 1));
    });

    on<CounterDecrementPressed>((event, emit) {
      emit(CounterState(counterValue: state.counterValue - 1));
    });
  }
}

步骤 5: 使用BlocBuilder来构建UI

最后,在main.dart或其他任何你想要显示计数器的地方,使用BlocProvider和BlocBuilder来构建UI。

dart 复制代码
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
import 'counter_bloc.dart';
import 'counter_event.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: BlocProvider(
        create: (context) => CounterBloc(),
        child: CounterPage(),
      ),
    );
  }
}

class CounterPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(title: Text('Counter')),
      body: Center(
        child: BlocBuilder<CounterBloc, CounterState>(
          builder: (context, state) {
            return Text(
              '${state.counterValue}',
              style: Theme.of(context).textTheme.headline4,
            );
          },
        ),
      ),
      floatingActionButton: Column(
        mainAxisAlignment: MainAxisAlignment.end,
        children: <Widget>[
          FloatingActionButton(
            onPressed: () => context.read<CounterBloc>().add(CounterIncrementPressed()),
            tooltip: 'Increment',
            child: Icon(Icons.add),
          ),
          SizedBox(height: 10),
          FloatingActionButton(
            onPressed: () => context.read<CounterBloc>().add(CounterDecrementPressed()),
            tooltip: 'Decrement',
            child: Icon(Icons.remove),
          ),
        ],
      ),
    );
  }
}

这个简单的计数器应用演示了BLoC模式的基本使用:定义事件(CounterEvent)、状态(CounterState)和业务逻辑组件(CounterBloc),然后在UI层通过BlocBuilder根据状态变化来构建相应的UI。通过这种方式,可以将业务逻辑与UI表示分离,使得代码更加模块化和易于管理。

相关推荐
木子雨廷几秒前
Flutter Redux 项目实战
flutter
AI_零食8 分钟前
Flutter 框架跨平台鸿蒙开发 - 颜色听觉化应用
学习·flutter·信息可视化·开源·harmonyos
2301_8227032014 分钟前
大学生体质健康测试全景测绘台:基于鸿蒙Flutter的多维数据可视化与状态管理响应架构
算法·flutter·信息可视化·架构·开源·harmonyos·鸿蒙
独特的螺狮粉15 分钟前
生命科学实验室经费极简记账簿:基于鸿蒙Flutter的极简主义状态响应与流式布局架构
flutter·华为·架构·开源·harmonyos
HH思️️无邪16 分钟前
Flutter + iOS 实战指南:教程视频 PiP + 退桌面(可复用模板)
flutter·ios
提子拌饭13318 分钟前
红细胞代偿性增殖与睡眠剥夺的对照演算引擎:基于鸿蒙Flutter的微观流体力学粒子渲染架构
flutter·华为·架构·开源·harmonyos·鸿蒙
浮芷.26 分钟前
Flutter 框架跨平台鸿蒙开发 - 智能家电故障诊断应用
运维·服务器·科技·flutter·华为·harmonyos·鸿蒙
浮芷.33 分钟前
Flutter 框架跨平台鸿蒙开发 - 急救指南应用
学习·flutter·华为·harmonyos·鸿蒙
提子拌饭13334 分钟前
液相色谱质谱联用(LC-MS)数据可视化引擎:基于鸿蒙Flutter的高精度色谱卡与多维峰值拟合架构
flutter·华为·信息可视化·开源·harmonyos·鸿蒙
Utopia^38 分钟前
Flutter 框架跨平台鸿蒙开发 - 社交星系
flutter·华为·harmonyos