我目前正在尝试学习状态管理,并且具有下面的代码,但是由于某种原因,状态从未更新过,我缺少什么吗?
import 'package:equatable/equatable.dart';
import 'package:flutter/material.dart';
import 'package:flutter_bloc/flutter_bloc.dart';
void main() {
runApp(MyApp());
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
home: BlocProvider(
create: (context) => ItemBloc(),
child: MyHomePage(),
),
);
}
}
class MyHomePage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text("Bloc Demo"),
),
body: Lister(),
floatingActionButton: FloatingActionButton(
onPressed: () {
ItemBloc().add(AddEvent());
},
tooltip: 'Increment',
child: Icon(Icons.add),
),
);
}
}
class Lister extends StatelessWidget {
@override
Widget build(BuildContext context) {
return BlocBuilder<ItemBloc, ListState>(
builder: (context, state) {
if (state is ListAdded) {
return ListView.builder(
itemCount: state.items.length,
itemBuilder: (context, index) {
return Text("item"); // This never increases in count
},
);
}
return Center(
child: Text('err'),
);
},
);
}
}
// BLOC
class ItemBloc extends Bloc<ListEvent, ListState> {
@override
get initialState => ListAdded(items: ["initial"]);
@override
Stream<ListState> mapEventToState(ListEvent event) async* {
if (event is AddEvent) {
final lister = ["first", "second"];
yield ListAdded(items: lister);
}
}
}
abstract class ListEvent extends Equatable {
@override
List<Object> get props => [];
}
class AddEvent extends ListEvent {}
abstract class ListState extends Equatable {
const ListState();
@override
List<Object> get props => [];
}
class ListAdded extends ListState {
final List<String> items;
const ListAdded({
this.items,
});
@override
List<Object> get props => [items];
@override
String toString() => 'ItemsLoaded { items: ${items.length} }';
}
请注意:我已尝试将代码分成单独的文件,然后将Bloc文件中的bloc.dart
软件包而不是flutter_bloc.dart
软件包导入
答案 0 :(得分:1)
这样做的时候
ItemBloc().add(AddEvent())
您正在创建新的bloc实例并向其添加事件。它没有与在MyApp
中创建并在Lister
中使用的一个连接。
您应该改为获取创建的集团:
BlocProvider.of<ItemBloc>(context).add(AddEvent())