Flutter GetX使用

下载地址:
https://pub-web.flutter-io.cn/packages/get

导入依赖:

dependencies:
  get: ^4.6.5

导入头文件:

import 'package:get/get.dart';

使用 Obx()GetX<T>()

创建全局数据 Counter,继承 GetxController

class Counter extends GetxController {
  /// 在使用GetX时,我们必须通过在值的末尾添加以下内容使变量可被观察到 **obs**在值的末尾加上然后,
  /// 当变量发生变化时,应用程序中依赖它的其他部分将得到通知。
  var count = 0.obs; // 等同于 RxInt count = 0.obs;

  increment() => count.value++;
}

添加依赖:

  /// 注入依赖
  Counter controller = Get.put(Counter());

添加组件 Obx() ,监听显示数据:

/// 监听数据: Obx 返回一个组件
Obx(
	() => Text('您点击了${controller.count}次'),
),

/// GetX<T>() 等同于 Obx()
GetX<Counter>(
	builder: (_) {
	return Text('您点击了${_.count}次');
	},
),

改变数据:

/// 改变数据
controller.increment();

使用 GetBuilder<T>()

创建全局数据 MyController 继承 GetxController

class MyController extends GetxController {
  var number = 0;

  add() {
    number++;
    update();// 监听数据更新
  }
}

添加依赖:

  MyController controller = Get.put(MyController());

添加组件 GetBuilder<T> :

              GetBuilder<MyController>(
                  init: controller,
                  initState: (_) {},
                  dispose: (state) {},
                  builder: (_) {
                    return Column(
                      children: [
                        Text('您点击了${_.number}次'),
                        ElevatedButton(
                          child: const Text("Click"),
                          /// 改变数据
                          onPressed: () => _.add(),
                        ),
                      ],
                    );
                  },
                ),

使用 ValueBuilder<T?>

                /// ValueBuilder 监听数据
                ValueBuilder<int?>(
                  initialValue: 0,
                  onDispose: () {},
                  onUpdate: (p0) => print("$p0"),
                  builder: (value, updater) {
                    return Column(
                      children: [
                        Text('您点击了$value次'),
                        ElevatedButton(
                          child: const Text("Click"),
                          onPressed: () {
                            value = (value ?? 0) + 1;
                            updater(value);//更新数据
                          },
                        ),
                      ],
                    );
                  },
                ),

在添加的依赖是全局的,考虑到内存释放问题,在页面deposit的时候需要释放controller

  
  void dispose() {
    super.dispose();
    /// 清除单例数据
    Get.delete<MyController>();
  }

如果需要到下一个页面访问该数据,需要使用 Get.find<T>() 函数:

MyController controller = Get.find<MyController>();

数据监听展示:

               GetBuilder(
                  init: controller,
                  builder: (_) {
                    return Column(
                      children: [
                        Text("${controller.number}"),
                        ElevatedButton(
                          child: const Text("Click"),
                          onPressed: () {
                            _.add();// 更新数据,上个页面的数据也会随之改变!!!
                          },
                        ),
                      ],
                    );
                  },
                )

此时会出现一个问题,就是如果想创建两个同类型的model(即 runtimeType 相同)需要如何区分呢?这时需要用到 tag 参数,主要下面三个函数:

/// 添加依赖
MyController controller = Get.put(MyController(), tag: "one");
MyController controller = Get.put(MyController(), tag: "two");

/// 访问数据
MyController controller = Get.find<MyController>(tag: "one");
MyController controller = Get.find<MyController>(tag: "two");

/// 删除数据
Get.delete<MyController>(tag: "one");
Get.delete<MyController>(tag: "two");

上述主要用到 GetX状态管理功能,如果想使用它的路由管理功能需要将 MaterialApp 改为 GetMaterialApp,这时候是不需要 content 的,例如页面 push

Get.to(() => const Page());
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值