Flutter 利用路由监听页面的展示与否

这里写自定义目录标题

1、新建routeMonitor.dart文件:

dart 复制代码
import 'package:flutter/material.dart';

class AppRouteObserver {
  //这是实际上的路由监听器
  static final RouteObserver<ModalRoute<void>> _routeObserver =
      RouteObserver<ModalRoute<void>>();
  //这是个单例
  static final AppRouteObserver _appRouteObserver =
      AppRouteObserver._internal();

  AppRouteObserver._internal();
  //通过单例的get方法轻松获取路由监听器
  RouteObserver<ModalRoute<void>> get routeObserver {
    return _routeObserver;
  }

  factory AppRouteObserver() {
    return _appRouteObserver;
  }
}

2、修改main.dart:

dart 复制代码
MaterialApp(
      navigatorObservers: [AppRouteObserver().routeObserver],
);

3.监听页面显隐的页面

dart 复制代码
class _XXX extends State<XXX> with RouteAware {
...
  @override
  void didChangeDependencies() {
    // TODO: implement didChangeDependencies
    super.didChangeDependencies();

    /// 路由订阅
    AppRouteObserver().routeObserver.subscribe(this, ModalRoute.of(context)!);
  }

  @override
  void dispose() {
    // TODO: implement dispose
    /// 取消路由订阅
    AppRouteObserver().routeObserver.unsubscribe(this);
    super.dispose();
  }

  @override
  void didPush() {
    print('跳转该页面而显示');
  }

  @override
  void didPop() {
    print('当前页面被pop而隐藏');
  }

  @override
  void didPopNext() {
    print('上一个页面关闭而显示');
  }

  @override
  void didPushNext() {
    print('跳转下一个页面而隐藏');
  }
  ...
}
相关推荐
mysusheng4 分钟前
Chrome 浏览器的很多扩展不能用了
前端·chrome
yeyuningzi6 分钟前
关于软航OFFICE文档控件软件在Chrome 133版本上提示扩展已停用的原因及处理办法
前端·扩展程序·manifest v3·ntko office控件·manifest v2·chrome 扩展机制变化
星空寻流年12 分钟前
css盒子模型第二章(margin padding border content)
前端·css
全宝12 分钟前
❤️前端boy该如何上手HarmonyOS?
前端·harmonyos
fruge14 分钟前
【vue2 + Cesium】相机视角移动+添加模型、模型点击事件
前端
henujolly35 分钟前
如何进行技术选型?
前端
束尘36 分钟前
React前端开发中实现断点续传
前端·javascript·react.js
一蓑烟雨,一任平生36 分钟前
React-state响应式内部数据(类组件&Hook两种方式整理)
前端·javascript·react.js
好_快1 小时前
Lodash源码阅读-matchesStrictComparable
前端·javascript·源码阅读
好_快1 小时前
Lodash源码阅读-toKey
前端·javascript·源码阅读