Ege*_*Ege 7 android dart flutter
我正在构建一个具有本地数据库的应用程序,并且我在该数据库中保留了一些关于电影的信息。有一个名为“收藏夹”的屏幕,我从本地数据库中获取电影并将它们放在列表视图中:
如果我单击该列表中的任何电影,我将被定向到一个新屏幕,在那里我可以查看电影详细信息。在这个屏幕上,有一个按钮可以从本地数据库中删除电影。
现在我的问题从这里开始:从数据库中删除任何电影并返回“收藏夹”屏幕后,我仍然在 ListView 中看到那部电影。但是我已经从数据库中删除了那部电影。如果我在 Android 平台上这样做,我会覆盖 onStart 方法并对数据库进行查询,然后更新列表视图。但据我所知,在 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")
);
}
}
Run Code Online (Sandbox Code Playgroud)
编辑:
我曾尝试使用 WidgetsBindingObserver 但它没有帮助。
@override
void didChangeAppLifecycleState(AppLifecycleState state) {
super.didChangeAppLifecycleState(state);
if(state == AppLifecycleState.resumed){
favoriteMovieDatabase
.getAllFavoriteMovies()
.then((List<MovieOverview> list) {
setState(() {
movieOverviewList = list;
});
});
}
}
Run Code Online (Sandbox Code Playgroud)
它甚至没有调用这个方法。
作为一个简单的解决方案,您可以等待导航器推送的结果:
goToDetailPage(BuildContext context) async {
await Navigator.of(context).pushNamed('movieDetail');
// this is reached when the route is popped
reloadData();
}
Run Code Online (Sandbox Code Playgroud)
为了使代码更加高效,您可以从详细信息路由返回一个结果,表明电影是否已被删除:
Navigator.pop(context, 'MOVIE_DELETED');
Run Code Online (Sandbox Code Playgroud)
和
goToDetailPage(BuildContext context) async {
final result = await Navigator.of(context).pushNamed<String>('movieDetail');
if(result == 'MOVIE_DELETED') {
reloadData();
}
}
Run Code Online (Sandbox Code Playgroud)
从长远来看,当有更多的方法来改变数据库内容时(想想一个半透明的对话框,其中电影列表在后台仍然可见,或者实时更新),最好转向某种类似于安卓上的房间。
假设您的问题发生在您用于Navigator推送新路由时,那么您可以使用RouteAwaremixin 与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();
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1606 次 |
| 最近记录: |