Flutter 使用 Getx 实现同一个界面被循环跳转多次并刷新数据的解决方案

在开发中的过程中可能会遇到这样的需求:同一个界面被循环跳转多次并且通过传递的参数不同刷新当前界面的数据。

场景如下:

接下来我们看下分析看,如何解决这个问题。

我们常用的方式是创建一个View extends GetView, 再创建 Controller extends GetxController,然后在 app_pages.dart文件中配置路由,然后就可以调用Getx提供的路由方法(比如:Get.toNamed )跳转到界面了,大概像下面这样(忽略细节):

View

scala 复制代码
class HomePage extends GetView<HomePageController> {
  const ScreenPage({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    
    return Scaffold(
      appBar: null,
      body:SizedBox(
                  /// 省略布局
      ),
    );
  }
}

Controller

scala 复制代码
class HomePageController extends GetxController {

    @override
    void onInit()  {
        super.onInit();
        ///loading 数据
        }

}

路由配置

php 复制代码
static final routes = [
...
  GetPage(
    name: _Paths.HOME,
    page: () => const HomePage(),
    binding: BindingsBuilder((){
        Get.lazyPut<HomePageController>(()=>HomePageController());
    })

  ),
  ...
  ]

跳转

css 复制代码
Get.toNamed(Routes.HOME, arguments: {"arg1": 0, "arg2": 0});

我们注意到路由配置中使用到了,Get.lazyPut ,当你调过一次这个控制器后就会被缓存起来,直到这个控制器被销毁前它都是同一个实例,也就是俗称的单例。当在一个app中出现循环调用同一个界面时,它绑定的控制器不会重新初始化,导致界面数据不会被刷新。

怎么办呢?

这个时候我们的主角就上场了,他就是 "冷门" 而强大的 Get.create 搭配 GetWidget 使用就能解决我们遇到的问题。顾名思义,Get.create会在每次调用该控制器时重新创建一个新的实例控制器,且保留当前数据。

View 中的 GetView 替换为 GetWidget, 路由配置中的 Get.lazyPut 替换为 Get.create,这样就能实现同一个界面被循环跳转多次并且通过传递的参数不同刷新当前界面的数据的需求了。

更改后的代码:

View

scala 复制代码
class HomePage extends GetWidget<HomePageController> {
  const ScreenPage({Key? key}) : super(key: key);

  @override
  Widget build(BuildContext context) {
    
    return Scaffold(
      appBar: null,
      body:SizedBox(
                  /// 省略布局
      ),
    );
  }
}

路由配置

php 复制代码
static final routes = [
...
  GetPage(
    name: _Paths.HOME,
    page: () => const HomePage(),
    binding: BindingsBuilder((){
        Get.create<HomePageController>(()=>HomePageController());
    })

  ),
  ...
  ]

问题解决了,开心。

相关推荐
kirk_wang42 分钟前
Flutter艺术探索-Flutter调试工具:DevTools使用指南
flutter·移动开发·flutter教程·移动开发教程
小雨下雨的雨2 小时前
Flutter 框架跨平台鸿蒙开发 —— SingleChildScrollView 控件之长内容滚动艺术
flutter·ui·华为·harmonyos·鸿蒙
牛马1112 小时前
Flutter 多语言
前端·flutter
getapi4 小时前
在 Google Play 上更新你已上架的 Flutter 应用
flutter·googlecloud·web app
奋斗的小青年!!5 小时前
Flutter跨平台开发适配OpenHarmony:文件系统操作深度实践
flutter·harmonyos·鸿蒙
西西学代码6 小时前
Flutter---路径管理器项目
flutter
奋斗的小青年!!6 小时前
Flutter跨平台开发OpenHarmony应用:个人中心实现
开发语言·前端·flutter·harmonyos·鸿蒙
LawrenceLan7 小时前
Flutter 零基础入门(十五):继承、多态与面向对象三大特性
开发语言·前端·flutter·dart
Rysxt_7 小时前
Flutter与UniApp底层逻辑深度对比
flutter·uni-app