gpt4 book ai didi

Flutter:带有初始网络请求的 ChangeNotifierProvider

转载 作者:行者123 更新时间:2023-12-02 13:33:17 27 4
gpt4 key购买 nike

我有一个代表电影列表的小部件,在我的模型中,我有 getMovies() 函数,它从网络请求中检索电影列表:

enum MovieListState { IDLE, LOADING, ERROR }

class MovieListModel extends ChangeNotifier {
MovieListModel(this._client);

GatewayClient _client;

MovieListState _viewState = MovieListState.LOADING;

MovieListState get viewState => _viewState;

set viewState(MovieListState value) {
_viewState = value;
notifyListeners();
}

Future<List<Movie>> getMovies() async {
try {
viewState = MovieListState.LOADING;
var movies = await _client.getMovies();
viewState = MovieListState.IDLE;
return movies;
} on KoException catch (e) {
viewState = MovieListState.ERROR;
throw e;
}
}
}

然后,我想从小部件中根据请求的状态构建布局:

@override
Widget build(BuildContext context) {
state = Provider.of<AppState>(context);
var model = MovieListModel(Provider.of<GatewayClient>(context));

return ChangeNotifierProvider<MovieListModel>.value(
value: model,
child: Consumer<MovieListModel>(builder: (context, model, child) {
if (model.viewState == MovieListState.IDLE) {
return _getList(); // Method which generates the content with the retrieved values
} else if (model.viewState == MovieListState.LOADING) {
return Center(
child: CircularProgressIndicator(),
);
} else {
return Center(
child: Text(_static.translate(context).movieListError),
);
}
}));
}

问题是,如何在小部件初始化开始时触发网络调用 getMovies() ?我尝试在不同的点手动调用 getMovies() 方法,但要么出现错误,要么每次小部件调用其 build() 方法时都会重复调用。

提前致谢。

最佳答案

使用 FutureProvider 修复:

  @override
Widget build(BuildContext context) {
return FutureProvider<List<Movie>>.value(
value: _model.getMovies(),
initialData: List<Movie>(),
catchError: (context, error) {
return null;
},
child: Consumer<List<Movie>>(
builder: (context, data, widget) {
// ...
},
),
);
}

关于Flutter:带有初始网络请求的 ChangeNotifierProvider,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57478943/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com