我正在构建一个具有本地数据库的应用程序,我在该数据库中保留了一些关于电影的信息.有一个名为“收藏夹”的屏幕,我从本地数据库中获取电影并将它们放在列表视图中: 如果我点击
如果我点击该列表中的任何电影,我将被引导到一个新的屏幕,我可以看到电影的详细信息.在此屏幕中,有一个按钮可从本地数据库中删除电影.
现在我的问题从这里开始:在我从数据库中删除任何电影并返回“收藏夹”屏幕后,我仍然在ListView中看到该电影.但我已经从数据库中删除了该电影.如果我在Android平台上做这个,我会覆盖onStart方法并对数据库进行查询,然后更新listview.但是只要我知道,Flutter就没有像onStart那样的方法.所以我该怎么做?
class FavoritesScreen extends StatefulWidget { @override _FavoritesScreenState createState() => _FavoritesScreenState(); } class _FavoritesScreenState extends State<FavoritesScreen> { var favoriteMovieDatabase = FavoriteMovieDatabase(); List<MovieOverview> movieOverviewList = List<MovieOverview>(); @override void initState() { super.initState(); favoriteMovieDatabase .getAllFavoriteMovies() .then((List<MovieOverview> list) { setState(() { movieOverviewList = list; }); }); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar(title: Text("Favorites")), body: MovieOverviewListView(movieOverviewList, "FAVORITE") ); } }
编辑:
我曾尝试使用WidgetsBindingObserver,但它没有帮助.
@override void didChangeAppLifecycleState(AppLifecycleState state) { super.didChangeAppLifecycleState(state); if(state == AppLifecycleState.resumed){ favoriteMovieDatabase .getAllFavoriteMovies() .then((List<MovieOverview> list) { setState(() { movieOverviewList = list; }); }); } }
它甚至没有称这种方法.
假设当您使用Navigator推送新路由时发生问题,那么您可以使用RouteAware
mixin与
RouteObserver
结合使用,然后覆盖didPopNext方法.
每当路线再次可见时,都会调用didPopNext.
final RouteObserver<PageRoute> routeObserver = new RouteObserver<PageRoute>(); void main() { runApp(new MaterialApp( home: new Container(), navigatorObservers: [routeObserver], )); } class RouteAwareWidget extends StatefulWidget { State<RouteAwareWidget> createState() => new RouteAwareWidgetState(); } // Implement RouteAware in a widget's state and subscribe it to the RouteObserver. class RouteAwareWidgetState extends State<RouteAwareWidget> with RouteAware { @override void didChangeDependencies() { super.didChangeDependencies(); routeObserver.subscribe(this, ModalRoute.of(context)); } @override void dispose() { routeObserver.unsubscribe(this); super.dispose(); } @override void didPopNext() { // TODO: query DB again } @override Widget build(BuildContext context) => new Container(); }