flutter Android的onStart等效功能

js81xvg6  于 2023-01-27  发布在  Flutter
关注(0)|答案(4)|浏览(123)

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

如果我点击列表中的任何一部电影,我会被引导到一个新的屏幕,在那里我可以看到电影的详细信息。在这个屏幕上,有一个按钮,从本地数据库中删除电影。
现在我的问题从这里开始:当我从数据库中删除任何电影并返回到"收藏夹"屏幕后,我仍然在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")
    );
  }
}

编辑:
我尝试使用WidgetsBindingObserver,但没有帮助。

@override
  void didChangeAppLifecycleState(AppLifecycleState state) {
    super.didChangeAppLifecycleState(state);
    if(state == AppLifecycleState.resumed){
      favoriteMovieDatabase
          .getAllFavoriteMovies()
          .then((List<MovieOverview> list) {
        setState(() {
          movieOverviewList = list;
        });
      });
    }
  }

它甚至没有调用这个方法。

aurhwmvo

aurhwmvo1#

作为一个简单的解决方案,您可以等待导航器推送的结果:

goToDetailPage(BuildContext context) async {

  await Navigator.of(context).pushNamed('movieDetail');

  // this is reached when the route is popped
  reloadData();
}

为了使代码更加高效,您可以从详细路径返回一个结果,表示电影是否已被删除:

Navigator.pop(context, 'MOVIE_DELETED');

以及

goToDetailPage(BuildContext context) async {
  final result = await Navigator.of(context).pushNamed<String>('movieDetail');

  if(result == 'MOVIE_DELETED') {
    reloadData();
  }    
}

从长远来看,当有更多的方法来改变数据库内容时(想想一个半透明的对话框,其中电影列表仍然在后台可见,或者实时更新),最好转移到某种类似于Android上的Room的React式架构。

b1payxdu

b1payxdu2#

假设您的问题发生在使用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();
}
wkyowqbh

wkyowqbh3#

您可以使用initState来实现这一点:

@override
  void initState() {
    _doWhatYouWantToDo().then((value){
      print('Async done');
    });
    super.initState();
  }
yhqotfr8

yhqotfr84#

添加这些代码当你想运行方法弹出

Navigator.push(
            context,
            MaterialPageRoute(
              builder: (context) => ConversationScreen() ,
            )).then((value) {
           //add your method which you want to run on pop!! cheers
          setState(() {});
        });
      },

相关问题