cal*_*tus 4 async-await dart firebase flutter
在我的 main.dart 文件中,我想检查用户是否已登录以便将他引导到适当的屏幕。我正在使用 SharedPrefence 从 Firebase 存储用户详细信息。如何告诉我的函数等待 SharedPreference 异步函数完成执行,然后才能呈现适当的小部件。
下面是我的代码
Widget _gotoHomeScreen() {
AuthService.getuserPrefEmail().then((email) {
print(email);
AuthService.email = email;
if (email == null) {
return LoginScreen();
} else {
AuthService.uid = email;
return HomeMenuScreen();
}
});
Run Code Online (Sandbox Code Playgroud)
}
Geo*_*rge 18
你不必等待构建,你应该构建一些东西,向用户展示应用程序正在加载一些东西(或空白屏幕),然后在功能结束时重建。
您可以在创建小部件时将 Widget 变量设置为默认值,例如使用 a CircularProgressIndicator,然后使用 setState 更改它,如下所示:
class YourWidgetState extends State<YourWidget> {
Widget _body = CircularProgressIndicator(); // Default Body
@override
void initState(){
_gotoHomeScreen();
}
@override
Widget build(BuildContext context){
return _body;
}
Widget _gotoHomeScreen() {
AuthService.getuserPrefEmail().then((email){
AuthService.email = email;
if (email == null) {
setState(() => _body = LoginScreen());
} else {
AuthService.uid = email;
setState(() => _body = HomeMenuScreen());
}
});
}
}
Run Code Online (Sandbox Code Playgroud)
另一种方法是使用变量来通知您加载情况,例如bool finishedLoading,并在完成后调用setState更改值,使用email您设置的变量来了解用户何时登录,并进行条件构建,如下所示:
bool loading = true;
@override
Widget build(BuildContext context){
if(loading) return CircularProgressIndicator();
if(AuthService.email == null)
return LoginScreen();
else
return HomeMenuScreen();
}
Widget _gotoHomeScreen() {
AuthService.getuserPrefEmail().then((email){
AuthService.email = email;
if (email != null) {
AuthService.uid = email;
}
setState((){ loading = false; });
});
}
Run Code Online (Sandbox Code Playgroud)
小智 7
使用简单的 FutureBuilder!
https://api.flutter.dev/flutter/widgets/FutureBuilder-class.html
FutureBuilder<Email>(
future: AuthService.getuserPrefEmail(),
builder: (BuildContext context, AsyncSnapshot<String> snapshot) {
switch (snapshot.connectionState) {
case ConnectionState.active:
case ConnectionState.waiting:
return CircularProgressIndicator();
case ConnectionState.done:
if (snapshot.hasError) {
return Text('Error: ${snapshot.error}');
}
.... here route to your screen or set it how you want
}
},
)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
13024 次 |
| 最近记录: |