大佬教程收集整理的这篇文章主要介绍了嵌套小部件中的 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
),我都会收到下一个问题:
我了解问题的根本原因 - ProfileScreen
在小部件树中的 @H_545_7@materialApp 下,因此它无法访问 HomeScreen
中的 StreamProvIDer。
我怎样才能使它低于 HomeScreen
以便它可以访问提供程序?将来,为了可维护性和更广泛的访问范围,我希望将提供者限制在某些屏幕上。
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)
以上是大佬教程为你收集整理的嵌套小部件中的 Flutter 流提供程序?全部内容,希望文章能够帮你解决嵌套小部件中的 Flutter 流提供程序?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。