Android的onStart等效

我正在构建一个具有本地数据库的应用程序,我在该数据库中保留了一些关于电影的信息.有一个名为“收藏夹”的屏幕,我从本地数据库中获取电影并将它们放在列表视图中:

Favorites Screen

如果我点击该列表中的任何电影,我将被引导到一个新的屏幕,我可以看到电影的详细信息.在此屏幕中,有一个按钮可从本地数据库中删除电影.

现在我的问题从这里开始:在我从数据库中删除任何电影并返回“收藏夹”屏幕后,我仍然在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();
}

相关文章

这篇文章主要讲解了“FlutterComponent动画的显和隐怎么实现...
这篇文章主要讲解了“flutter微信聊天输入框功能如何实现”,...
本篇内容介绍了“Flutter之Navigator的高级用法有哪些”的有...
这篇文章主要介绍“Flutter怎么使用Android原生播放器”,在...
Flutter开发的android端如何修改APP名称,logo,版本号,具体...
Flutter路由管理初识路由概念一.路由管理1.1.Route1.2.Mater...