gpt4 book ai didi

dart - 如何在 Flutter 中使用 bloc 模式在 UI 上显示函数回调和错误?

转载 作者:IT王子 更新时间:2023-10-29 06:46:39 27 4
gpt4 key购买 nike

bloc.dart

class Bloc{
Bloc(){
additionalController.stream.listen(onAdd);
}

void dispose() async {
additionalController.close();
_itemAdd.close();
}

final additionalController = StreamController<Data>();
Sink<Data> get addItem => additionalController.sink;

Stream<String> get addGet => _itemAdd.stream;
final _itemAdd = BehaviorSubject<String>();

void onAdd(Data data) {
_addWork(data);
}

Future<Null> _addWork(Data data) async {

//work

}).whenComplete(() {

_itemAdd.add("complete work");

}).catchError((e) {
_itemAdd.addError("Error in Adding Data");
});
}
}

因为bloc应该只被使用和共享来处理业务逻辑,但错误处理部分与业务逻辑无关。

如何在 UI 上显示 bloc 的回调和错误。我不认为 StreamBuilder 是唯一的解决方案。

如果我们使用 StreamBuilder,那么,每次重建发生时,我们都会重复向 bloc 发送回调,这是没有意义的。

有正确的方法吗?

提前致谢!

最佳答案

到目前为止,对我有用的是使用表示回调的接口(interface)。

abstract class AddItemDelegate {
void onSuccess();
void onError(String message);
}

然后在bloc中使用如下:

class Bloc {
AddItemDelegate _delegate;
// ...
Function addItem(Data item, AddItemDelegate delegate) => () {
_delegate = delegate;
additionalController.sink.add(item);
}
// ...
Future<Null> _addWork(Data data) async {
try {
final work = await //work...
_itemAdd.add("complete work");
_delegate?.onSuccess();
}
catch(e) {
final error = "Error in Adding Data";
_itemAdd.addError(error);
_delegate?.onError(error);
}
}
}

然后在您的 StatefulWidget(或StatelessWidget)上,您可以执行以下操作:

class MyWidget extends StatelessWidget implements AddItemDelegate {
@override
void onSuccess() {
// e.g.: Show a dialog or navigate to other screen
}

@override
void onError(String message) {
// e.g.: Show an error dialog
}

@override
Widget build(BuildContext context) {
final bloc = // ...
final data = // ...
return MaterialButton(
child: Text("Add Item"),
onPressed: bloc.addItem(data, this));
}
}

这样一来,您就可以在使用 BLoC 模式时使用回调。

关于dart - 如何在 Flutter 中使用 bloc 模式在 UI 上显示函数回调和错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52914493/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com