Flutter 中的单例模式

传统:

dart 复制代码
class RouterManager {
  // 单例模式
  static final RouterManager _instance = RouterManager._internal();

  factory RouterManager() {
    return _instance;
  }

  RouterManager._internal();
}

传递参数进行初始化时:

dart 复制代码
class RouterManager {
  // 私有静态实例,确保单例
  static RouterManager? _instance;

  // goRouter 是 final 变量,确保它只被初始化一次
  final GoRouter goRouter;

  // 私有构造函数
  RouterManager._internal(this.goRouter);

  // 工厂方法,返回 RouterManager 实例
  factory RouterManager({String initialLocation = '/'}) {
    _instance ??= RouterManager._internal(buildRouter(initialLocation));
    return _instance!;
  }

  static GoRouter buildRouter(String initialLocation) {
    return GoRouter(
      initialLocation: initialLocation,
      routes: [
        GoRoute(path: '/', builder: (context, state) => const SplashPage()),
        GoRoute(path: '/home', builder: (context, state) => const HomePage()),
        GoRoute(
          path: '/detail/:id',
          builder: (context, state) {
            final id = state.pathParameters['id']!;
            return DetailPage(id: id);
          },
        ),
      ],
      errorBuilder:
          (context, state) => Scaffold(body: Center(child: Text('Error: ${state.error}'))),
    );
  }
}
相关推荐
sdgsdgdsgc1 小时前
Next.js企业级应用开发:SSR、ISR与性能监控方案
开发语言·前端·javascript
哲此一生9841 小时前
搭建Vue3工程(去除不必要的文件)
前端·javascript·vue.js
心止水j1 小时前
spark
javascript·数据库·spark
黑云压城After4 小时前
H5使用环信实现视频或语音通话
前端·javascript·vue.js
未来之窗软件服务5 小时前
自己写算法(九)网页数字动画函数——东方仙盟化神期
前端·javascript·算法·仙盟创梦ide·东方仙盟·东方仙盟算法
C+ 安口木7 小时前
vue中监听window某个属性被添加或值的变化
前端·javascript·vue.js
CoderYanger7 小时前
前端基础-HTML入门保姆级课堂笔记
前端·javascript·css·html
赛博切图仔7 小时前
qiankun、micro-app、wujie,2025年我们该选谁?
前端·javascript
im_AMBER9 小时前
Web 开发 27
前端·javascript·笔记·后端·学习·web
玩代码9 小时前
vue项目安装chromedriver超时解决办法
前端·javascript·vue.js