我正在构建一个具有本地数据库的应用程序,我在该数据库中保留了一些关于电影的信息.有一个名为“收藏夹”的屏幕,我从本地数据库中获取电影并将它们放在列表视图中: 如果我点击
如果我点击该列表中的任何电影,我将被引导到一个新的屏幕,我可以看到电影的详细信息.在此屏幕中,有一个按钮可从本地数据库中删除电影.
现在我的问题从这里开始:在我从数据库中删除任何电影并返回“收藏夹”屏幕后,我仍然在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();
}
