Get.lazyPut 的时机是什么时候,是在页面中使用了controller属性,并且加载了对应页面,才会注入控制器吗?

是的,Get.lazyPut<T> 是一种延迟注入的机制,它确保控制器实例只在第一次被实际需要时创建。具体来说,Get.lazyPut<T> 注册一个提供者函数,当你第一次通过 Get.find<T>() 查询或在一个 GetView<T> 页面中访问 controller 属性时,这个提供者函数会被调用来创建控制器实例。

这就意味着控制器并不会在 Get.lazyPut<T> 被调用时立即创建实例,而是在后续某个时间点------当控制器实际上需要时。这有助于减少应用启动时的资源消耗,并可以提高性能,因为不会预装载所有的控制器。

下面是一个 Get.lazyPut 的用法示例,演示了在绑定 (Bindings) 类中使用:

Dart 复制代码
class HomeBinding extends Bindings {
  @override
  void dependencies() {
    // HomeController 只有在第一次尝试访问时才会被创建
    Get.lazyPut<HomeController>(() => HomeController());
  }
}

HomeBinding 被用在 GetPage 的配置中并且页面被访问时,如下面的路由设置:

Dart 复制代码
GetPage(
  name: '/home',
  page: () => HomeView(),
  binding: HomeBinding(),
)

这个时候,一旦页面中的代码尝试访问 HomeController,比如一个 GetView<HomeController> 的子类访问它的 controller 属性,或者在页面中的某个地方调用了 Get.find<HomeController>()Get.lazyPut 提供的提供者函数就会被触发,HomeController 的实例将会被创建并注入到 GetX 的依赖注入系统中。

在这之后,你可以安全地通过 Get.find<T>() 或在 GetView<T> 中访问controller属性来获取控制器实例。以 GetView<T> 为例,在页面中,你通常会通过 controller 直接引用控制器,如下所示:

Dart 复制代码
class HomeView extends GetView<HomeController> {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('Home Page'),
      ),
      body: Center(
        // 通过 controller 属性访问 HomeController 实例
        // 如果 HomeController 尚未创建,将会触发 Get.lazyPut 的执行
        child: Text('Welcome ${controller.username}'),
      ),
    );
  }
}

在上面的代码中,假设 HomeController 中有一个 username 属性,那么当 HomeView Widget 构建并且尝试访问 controller.username 时,Get.lazyPut 将会被触发,此时 HomeController 的实例将被创建并可用。

如果是通过 Get.find<T>() 手动获取控制器实例的情况下,同样的规则适用:

Dart 复制代码
final homeController = Get.find<HomeController>();
// 如果 HomeController 尚未创建,将会触发 Get.lazyPut 的执行

在这个例子中,如果之前没有访问过 HomeController 而触发过 Get.lazyPut 的执行,那么调用 Get.find<HomeController>() 将会实例化控制器。

总结来说,Get.lazyPut 允许你使用延迟加载的方式注册控制器,只有当控制器实际被需要时,GetX 才会创建控制器实例。这样做既优化了性能,也保证了资源的有效使用,因为你不需要一开始就加载所有的控制器实例,尤其是对于那些可能不会被立即使用的控制器。

相关推荐
problc9 小时前
Flutter中文字体设置指南:打造个性化的应用体验
android·javascript·flutter
lqj_本人17 小时前
鸿蒙next选择 Flutter 开发跨平台应用的原因
flutter·华为·harmonyos
lqj_本人20 小时前
Flutter&鸿蒙next 状态管理框架对比分析
flutter·华为·harmonyos
起司锅仔1 天前
Flutter启动流程(2)
flutter
hello world smile1 天前
最全的Flutter中pubspec.yaml及其yaml 语法的使用说明
android·前端·javascript·flutter·dart·yaml·pubspec.yaml
lqj_本人1 天前
Flutter 的 Widget 概述与常用 Widgets 与鸿蒙 Next 的对比
flutter·harmonyos
iFlyCai1 天前
极简实现酷炫动效:Flutter隐式动画指南第二篇之一些酷炫的隐式动画效果
flutter
lqj_本人1 天前
Flutter&鸿蒙next 中使用 MobX 进行状态管理
flutter·华为·harmonyos
lqj_本人1 天前
Flutter&鸿蒙next 中的 setState 使用场景与最佳实践
flutter·华为·harmonyos
hello world smile1 天前
Flutter常用命令整理
android·flutter·移动开发·android studio·安卓