Method 1 :你可以用StreamBuilder来做这个.每当stream中的数据发生变化时,将运行builder方法.
下面是我的一个示例项目的代码片段:
StreamBuilder<List<Content>> _getContentsList(BuildContext context) {
final BlocProvider blocProvider = BlocProvider.of(context);
int page = 1;
return StreamBuilder<List<Content>>(
stream: blocProvider.contentBloc.contents,
initialData: [],
builder: (context, snapshot) {
if (snapshot.data.isNotEmpty) {
return ListView.builder(itemBuilder: (context, index) {
if (index < snapshot.data.length) {
return ContentBox(content: snapshot.data.elementAt(index));
} else if (index / 5 == page) {
page++;
blocProvider.contentBloc.index.add(index);
}
});
} else {
return Center(
child: CircularProgressIndicator(),
);
}
});
}
在上面的代码中,StreamBuilder监听内容的任何更改,最初是一个空数组,并显示CircularProgressIndicator.一旦我调用API,获取的数据就会被添加到contents数组中,该数组将运行builder方法.
当用户向下滚动时,将获取更多内容并将其添加到内容数组,该数组将再次运行builder方法.
在您的情况下,只需要初始加载.但这为您提供了在获取数据之前在屏幕上显示其他内容的选项.
希望这能对您有所帮助.
EDIT:个
在您的情况下,我猜它将如下所示:
StreamBuilder<List<Content>>(
stream: account, // stream data to listen for change
builder: (context, snapshot) {
if(account != null) {
return _googleSignIn.signInSilently();
} else {
// show loader or animation
}
});
Method 2:另一个方法是创建一个async
方法,并从您的initState()
方法中调用它,如下所示:
@override
void initState() {
super.initState();
asyncMethod();
}
void asyncMethod() async {
await asyncCall1();
await asyncCall2();
// ....
}