有一个StreamBuilder(使用RxDart)显示一些日期。单击InkWell小部件后,我需要根据旧日期计算一个新日期。下面的代码只是简单地解释了算法,但是当我运行它时,什么都没有发生,并且在带下划线的行之后执行停止,即,我从未看到 lastCalcDate 的值。
GUI:
child: StreamBuilder(
stream: bloc.getDate,
builder: (context,snapshot) {
return InkWell(
onTap: () => tapHandler
);
}),
void tapHandler() async {
var lastCalcDate = await bloc.getDate.single;
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
print(lastCalcDate);
var newCalcDate = lastCalcDate.add(Duration(days:1));
bloc.setDate(newCalcDate)
}
BLoC:
class Bloc {
// BehaviourSubject is usedto be sure that last sent date will be accessible in `tapHandler`.
final _dateSubject = BehaviourSubject<DateTime>();
Observable<DateTime> get getDate => _dateSubject.stream;
Function(DateTime) get setDate => _dateSubject.add;
}
要实现我需要的功能,我创建了一些解决方法,但我不喜欢它,因为我认为我可以使用可观察对象来做同样的事情。
BLoC(解决方法):
class Bloc {
final _dateSubject = BehaviourSubject<DateTime>();
Observable<DateTime> get getDate => _dateSubject.stream;
DateTime _date;
void setDateWorkaround(DateTime date) {
_date = date;
_dateSubject.add(date);
}
}
您能给我个建议吗?我做错了什么?
答案 0 :(得分:0)
single
将不起作用,因为它将返回流中的下一个项目,但是必须首先添加。这意味着single
将只等待下一个项目,而在您的情况下则不会发生。
由于您已经在使用rxdart
和BehaviorSubject
,因此可以像这样轻松地访问当前元素:
class Bloc {
final _dateSubject = BehaviourSubject<DateTime>();
Observable<DateTime> get getDate => _dateSubject.stream;
Function(DateTime) get setDate => _dateSubject.add;
DateTime get currentDate => _dateSubject.value;
}
在这种情况下,我使用的是BehaviorSubject.value
,这实际上是该课程的重点。
现在,您只需在点击处理程序中使用currentDate
:
void tapHandler() async {
var lastCalcDate = bloc.currentDate;
print(lastCalcDate);
var newCalcDate = lastCalcDate.add(Duration(days:1));
bloc.setDate(newCalcDate)
}