程序问答   发布时间:2022-06-01  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了嵌套小部件中的 Flutter 流提供程序?大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决嵌套小部件中的 Flutter 流提供程序??

开发过程中遇到嵌套小部件中的 Flutter 流提供程序?的问题如何解决?下面主要结合日常开发的经验,给出你关于嵌套小部件中的 Flutter 流提供程序?的解决方法建议,希望对你解决嵌套小部件中的 Flutter 流提供程序?有所启发或帮助;

不确定问题的标题是否正确,所以我想在下面更详细地描述它。提供程序的所有示例都显示了在 MaterialApp 上方使用提供程序的情况,但是我很感兴趣并希望在 MaterialApp 的“下方”使用它。

请看下面的代码。

应用的@H_545_7@main.dart

// ...
return MultiProvIDer(
      provIDers: [
        ChangeNotifIErProvIDer(create: (_) => ProvIDer1()),ChangeNotifIErProvIDer(create: (_) => ProvIDer2()),ChangeNotifIErProvIDer(create: (_) => ProvIDer3()),],builder: (context,child) {
        return MaterialApp(
          title: 'My app',theme: themeData(
            priMarySwatch: colors.blue,),home: SplashScreen(),deBUGShowcheckedModeBAnner: false,);
      },);
// ...

SplashScreen 决定是将用户移动到主页还是注册/登录屏幕:

return Scaffold(
      body: StreamBuilder<User?>(
          stream: FirebaseAuth.instance.authStateChanges(),snapshot) {
            if (snapshot.hasError) {
              return RegistrationScreen();
            }

            if (snapshot.connectionState == ConnectionState.waiTing) {
              return Container();
            }

            var user = snapshot.data;

            if (user == null) {
              log('User is signed out.');
              return RegistrationScreen();
            } else {
              log('Signed in user: $user');

              return FutureBuilder<querySnapshot>(
                  future: usersCollection
                      .where('email',isEqualTo: user.email)
                      .get(),snapshot) {
                    if (snapshot.hasError) {
                      return RegistrationScreen();
                    }

                    if (snapshot.connectionState == ConnectionState.waiTing) {
                      return Container();
                    }

                    if (snapshot.data == null) {
                      return RegistrationScreen();
                    } else {
                      return HomeScreen(snapshot.data!.docs[0].referencE);
                    }
                  });
            }
          }),);

现在我们进入问题所在的部分。这个想法是让 HomeScreen 监听 Firebase 用户的变化,以便每个感兴趣的底层小部件都能做出适当的反应(注销、更新标题中的用户名或其他)。

HomeScreen 代码如下所示:

class HomeScreen extends StatefulWidget {
  final documentReference user;

  HomeScreen(thiS.User);

  @overrIDe
  _HomeScreenState createState() => _HomeScreenState();
}

class _HomeScreenState extends State<HomeScreen> {
  @overrIDe
  Widget build(BuildContext context) {
    return FutureBuilder<documentSnapshot>(
        future: Widget.user.get(),snapshot) {
          if (snapshot.hasError) {
            return SplashScreen();
          }

          if (snapshot.connectionState == ConnectionState.waiTing) {
            return Container();
          }

          var user = snapshot.data!;

          return StreamProvIDer<documentSnapshot>(
            create: (_) => Widget.user.snapshots(),initialData: user,child) {
              return Scaffold(
                  appbar: Appbar(
                    title: Text('My List of data'),actions: <Widget>[
                      Iconbutton(
                          icon: Icon(Icons.account_circle_outlined,color: colors.whitE),onpressed: () {
                            Navigator.push(
                                context,MaterialPageRoute(
                                    builder: (context) => ProfileScreen()));
                          })
                    ],body: MylistofDataScreen());
            },);
        });
  }
}

但是每当我离开屏幕时(例如使用应用栏操作或其他操作到 ProfileScreen),我都会收到下一个问题:

嵌套小部件中的 Flutter 流提供程序?

我了解问题的根本原因 - ProfileScreen 在小部件树中的 @H_545_7@materialApp 下,因此它无法访问 HomeScreen 中的 StreamProvIDer。

嵌套小部件中的 Flutter 流提供程序?

我怎样才能使它低于 HomeScreen便它可以访问提供程序?将来,为了可维护性和更广泛的访问范围,我希望将提供者限制在某些屏幕上。

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

大佬总结

以上是大佬教程为你收集整理的嵌套小部件中的 Flutter 流提供程序?全部内容,希望文章能够帮你解决嵌套小部件中的 Flutter 流提供程序?所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。
标签:Flutter