在应用程序主页上,我设置了Model2
对数据进行 API 调用的设置。然后用户可以导航到其他页面 ( Navigator.push
)。但我想Model2
在用户按下(_onBackPress()
)时进行 API 调用,以便刷新主页上的数据。当我打电话时,它给出了错误:
未处理的异常:错误:在此消费者小部件上方找不到正确的提供者
如果我添加Consumer
到 Page2 它会给出错误:
错误:在此消费者小部件上方找不到正确的提供者
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 页中:
final context;
Page2State({Key key, this.context});
...
// Consumer<Model2>(
// builder: (context, model2, _) =>
...
onWillPop: () => _onBackPress(context),
...
Future<void> _onBackPress(context) async {
final model2 = Provider.of<Model2>(context, listen: false);
return showDialog<void>(
context: context,
barrierDismissible: false,
builder: (BuildContext context) {
return
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 {
await model2.getData();
Navigator.of(context).pop();
},
),
],
),
);
},
);
}