0

我正在使用 StreamProvider 来捕获 Firestore 中发生的更改并将它们显示在用户主页上。当用户最初登录或注册时,他们会被定向到这个主页并希望看到他们的详细信息,为此我使用了 StreamProvider。

请记住,获取的第一个值将为空,我添加了一个加载文本小部件。但是,除非我热刷新页面并且有状态的小部件再次重建,否则小部件似乎不会改变。似乎正在发生的事情是,我作为主页使用的有状态小部件仅“构建”一次,因此即使流填充了非空值,加载小部件也不会消失,因为它的父小部件没有t得到重建。

这是我用来包装我的 StreamProvider 的基本 HomeScreen 小部件。

@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, 0, 0, 5),
             child: Text(_data != null ? _data.name : 'LOADING...', style: dashboardName),
                ),
              ],
            ),
     Row(
       children: [
          Padding(
              padding: const EdgeInsets.fromLTRB(25, 2, 0, 5),
              child: Text(_data != null ? _data.scholarId : 'LOADING...', style: dashboardName),
                ),
              ],
            ),

我还注意到,我用于调试的打印语句仅在打印那些初始空值时才会执行,直到我热刷新页面并显示非空值。

有没有办法解决这个问题?我已经被困了几天,没有取得任何重大进展,任何形式的指导都将不胜感激。

4

0 回答 0