问题描述
我正在使用 StreamProvider 来捕获 Firestore 中发生的更改并将其显示在用户主页上。当用户最初登录或注册时,他们会被定向到此主页并希望看到他们的详细信息,为此我使用了 StreamProvider。
请记住,获取的第一个值将为空,因此我添加了一个加载文本小部件。但是,除非我热刷新页面并再次重建有状态小部件,否则小部件似乎不会改变。 似乎正在发生的事情是,我用作主页的有状态小部件仅“构建”一次,因此即使流填充了非空值,加载小部件也不会消失,因为它的父小部件没有t 重建。
这是一个基本的 HomeScreen 小部件,我正在围绕它包装我的 StreamProvider。
@Override
Widget build(BuildContext context) {
return StreamProvider<UserDataModel>.value(
initialData: null,value: DatabaseServices(userDetails: _userDetails).userDataDocument,updateShouldNotify: (prevIoUs,current) => true,child: Scaffold(
backgroundColor: Colors.white,body: HomeBody(),)
);
}
这是来自 HomeBody 小部件的相关片段
class HomeBody extends StatefulWidget {
@override
_HomeBodyState createState() => _HomeBodyState();
}
class _HomeBodyState extends State<HomeBody> {
@override
Widget build(BuildContext context) {
final AuthenticationServices _authServices = AuthenticationServices();
final UserDataModel _data = Provider.of<UserDataModel>(context);
print(_data);
print((_data != null) ? _data.name : 'NULL');
/* Some code */
Row(
children: [
Padding(
padding: const EdgeInsets.fromLTRB(25,5),child: Text(_data != null ? _data.name : 'LOADING...',style: dashboardName),),],Row(
children: [
Padding(
padding: const EdgeInsets.fromLTRB(25,2,child: Text(_data != null ? _data.scholarId : 'LOADING...',
我还注意到,我用于调试的打印语句仅在打印这些初始空值时执行,直到我热刷新页面并显示非空值。
有没有办法解决这个问题?我已经被困了几天,没有取得任何重大进展,任何形式的指导都将不胜感激。
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)