在应用程序主页上,我设置了Model2
对数据进行 API 调用的设置。然后用户可以导航到其他页面 ( Navigator.push
)。但我想Model2
在用户按下(_onBackPress()
)时进行 API 调用,以便刷新主页上的数据。
问题是 Model2 没有为所有用户初始化。但是,如果我调用final model2 = Provider.of<Model2>(context, listen: false);
未初始化 Model2 的用户,则会出错。
我如何只能在有条件的情况下致电提供者?例如:if(user == paid)
StatefulWidget
在主页中:
@override
Widget build(BuildContext context) {
return ChangeNotifierProxyProvider<Model1, Model2>(
initialBuilder: (_) => Model2(),
builder: (_, model1, model2) => model2
..string = model1.string,
),
child: Consumer<Model2>(
builder: (context, model2, _) =>
...
Navigator.push(
context,
MaterialPageRoute(builder: (context) => SecondRoute(context: context)),
在第 2 页中:
Future<void> _onBackPress(context) async {
// if(user == paid)
final model2 = Provider.of<Model2>(context, listen: false);
return showDialog<void>(
context: context,
barrierDismissible: false,
builder: (BuildContext context) {
return
// if(user == paid)
Provider.value(value: model2, child:
AlertDialog(
title: Text('Back'),
content: SingleChildScrollView(
child: ListBody(
children: <Widget>[
Text('Go back'),
],
),
),
actions: <Widget>[
FlatButton(
child: Text('OK'),
onPressed: () async {
// if(user == paid)
await model2.getData();
Navigator.of(context).pop();
},
),
],
),
);
},
);
}
替代方法(可能更简单):如何在上一页(主页)上调用提供者Navigator.of(context).pop();
?
TLDR:调用 API 的最佳解决方案是什么,以便在用户返回上一页时刷新数据(但仅适用于某些用户)?