Flutter GetX 状态管理 响应式编程(三)

Flutter GetX 状态管理 响应式编程(三)在 2021 年 Provider 扩展了 5 0 使用起来更方便 于是我重新录制制作了一期教程 大家可以查看一下我的视频 在 Flutter 开发中 跨组件通信 数据更新 这些常被称为状态管理 GetX 是一个比较轻量级的状态管理框架 本节讲解的

欢迎大家来到IT世界,在知识的湖畔探索吧!

在2021年,Provider扩展了5.0,使用起来更方便,于是我重新录制制作了一期教程,大家可以查看一下我的视频。

Flutter GetX 状态管理 响应式编程(三)



欢迎大家来到IT世界,在知识的湖畔探索吧!

Flutter 开发中,跨组件通信,数据更新,这些常被称为状态管理,GetX 是一个比较轻量级的状态管理框架,本节讲解的是 响应式编程的基本使用。

在2021年4月初,我们在应用开发中大量使用了 GetX,目前看来效果还不错,于是我最近也出了一套GetX的从入门到源码原理的分析教程,欢迎大家关注更新。

第一步 使用 GetMaterialApp

//程序入口 void main() { runApp(RootApp()); } class RootApp extends StatelessWidget { @override Widget build(BuildContext context) { //使用 GetX第一步 return GetMaterialApp( theme: ThemeData( primarySwatch: Colors.blue, ), //默认显示的首页页面 home: CountObsMainPage(), ); } }

欢迎大家来到IT世界,在知识的湖畔探索吧!

GetMaterialApp 对于路由、snackbar、国际化、bottomSheet、对话框以及与路由相关的高级apis和没有上下文(context)的情况下是起重要作用的,它只是一个Widget,它的子组件是默认的MaterialApp。

第二步定义 Controller

欢迎大家来到IT世界,在知识的湖畔探索吧! import 'package:get/get.dart'; class CountObsController extends GetxController { //声明为被观察者 RxInt _count = 0.obs; RxInt get getCount => _count; //操作方法 void addCount() { _count++; } } 

第三步 操作数据与显示数据

就是定义就是定义页面主体显示 你甚至都不用使用 StatefulWidget,代码如下:

class CountObsMainPage extends StatelessWidget { @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text("Gex 响应编程"), ), backgroundColor: Colors.white, ///填充布局 body: Container( padding: EdgeInsets.all(30), width: double.infinity, height: double.infinity, child: Column( children: [ GetX<CountObsController>( //初始化控制器 init: CountObsController(), //监听回调 builder: (CountObsController controller) { return Text("当前 count 的值为 ${controller.getCount}"); }, ), //观察者自动更新 Obx(() { return Text( "Obx 当前 count 的值为 ${Get.find<CountObsController>().getCount}"); }), ], )), //点击按钮修改值 floatingActionButton: FloatingActionButton( child: Icon(Icons.add), onPressed: () { Get.find<CountObsController>().addCount(); }, ), ); } } 

完毕

不局限于思维,不局限语言限制,才是编程的最高境界。

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://itzsg.com/99496.html

(0)
上一篇 1小时前
下一篇 1小时前

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们YX

mu99908888

在线咨询: 微信交谈

邮件:itzsgw@126.com

工作时间:时刻准备着!

关注微信