Android和IOS应用开发-Flutter 应用中实现记录和使用全局状态的几种方法

news/2024/7/20 22:44:39 标签: android, ios, flutter, Provider, GetX, BLoc

在这里插入图片描述

文章目录

  • 在Flutter中记录和使用全局状态
  • 使用 Provider
    • 步骤1
    • 步骤2
    • 步骤3
  • 使用 BLoC
    • 步骤1
    • 步骤2
    • 步骤3
  • 使用 GetX
    • 步骤1
    • 步骤2
    • 步骤3

在Flutter中记录和使用全局状态

在 Flutter 应用中,您可以使用以下几种方法来实现记录和使用全局状态,并在整个应用程序中各个页面中使用:

Provider_7">使用 Provider

Provider 是 Flutter 中流行的状态管理库,它可以方便地在多个页面之间共享数据。

步骤1

创建一个类来表示您的全局状态,例如:

class AppState {
  int counter = 0;

  void incrementCounter() {
    counter++;
  }
}

步骤2

在应用程序的根目录中,使用 Provider 创建一个全局状态实例:

void main() {
  runApp(
    ChangeNotifierProvider(
      create: (_) => AppState(),
      child: MyApp(),
    ),
  );
}

步骤3

在任何页面中,使用 Provider.of 来获取全局状态实例并使用它:

class MyHomePage extends StatelessWidget {
  
  Widget build(BuildContext context) {
    final appState = Provider.of<AppState>(context);

    return Scaffold(
      appBar: AppBar(
        title: Text('MyApp'),
      ),
      body: Center(
        child: Column(
          children: [
            Text('${appState.counter}'),
            ElevatedButton(
              onPressed: () {
                appState.incrementCounter();
              },
              child: Text('Increment'),
            ),
          ],
        ),
      ),
    );
  }
}

使用 BLoC

BLoC 代表 Business Logic Component,是一种用于分离业务逻辑和 UI 的设计模式。

步骤1

创建一个 BLoC 类来管理您的全局状态,例如:

class AppBloc {
  final _counterController = StreamController<int>();

  Stream<int> get counterStream => _counterController.stream;

  void incrementCounter() {
    _counterController.sink.add(_counterController.value + 1);
  }
}

步骤2

在应用程序的根目录中,创建 BLoC 实例并将其作为依赖项注入到其他页面:

void main() {
  final appBloc = AppBloc();

  runApp(
    MyApp(
      appBloc: appBloc,
    ),
  );
}

步骤3

在任何页面中,使用 BLoC 实例来获取和更新全局状态:

class MyHomePage extends StatelessWidget {
  final AppBloc appBloc;

  MyHomePage({required this.appBloc});

  
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('MyApp'),
      ),
      body: Center(
        child: Column(
          children: [
            StreamBuilder<int>(
              stream: appBloc.counterStream,
              builder: (context, snapshot) {
                return Text('${snapshot.data}');
              },
            ),
            ElevatedButton(
              onPressed: () {
                appBloc.incrementCounter();
              },
              child: Text('Increment'),
            ),
          ],
        ),
      ),
    );
  }
}

GetX_141">使用 GetX

GetX 是另一个流行的状态管理库,它提供了一种简单的方式来管理全局状态和路由。

步骤1

创建一个类来表示您的全局状态,例如:

class AppState {
  int counter = 0;

  void incrementCounter() {
    counter++;
  }
}

步骤2

在应用程序的根目录中,使用 GetMaterialApp 创建一个应用程序并将其作为依赖项注入到其他页面:

void main() {
  runApp(
    GetMaterialApp(
      home: MyHomePage(),
      binding: BindingsBuilder(() {
        Get.put(AppState());
      }),
    ),
  );
}

步骤3

在任何页面中,使用 Get.find 来获取全局状态实例并使用它:

class MyHomePage extends StatelessWidget {
  
  Widget build(BuildContext context) {
    final appState = Get.find<AppState>();

    return Scaffold(
      appBar: AppBar(
        title: Text('MyApp'),
      ),
      body: Center(
        child: Column(
          children: [
            Text('${appState.counter}'),
            ElevatedButton(
              onPressed: () {
                appState.incrementCounter();
              },
              child: Text('Increment'),

结束语
Flutter是一个由Google开发的开源UI工具包,它可以让您在不同平台上创建高质量、美观的应用程序,而无需编写大量平台特定的代码。我将学习和深入研究Flutter的方方面面。从基础知识到高级技巧,从UI设计到性能优化,欢饮关注一起讨论学习,共同进入Flutter的精彩世界!

http://www.niftyadmin.cn/n/5442778.html

相关文章

电子科技大学链时代工作室招新题C语言部分---题号H

1. 题目 最有操作的一道题&#xff0c;有利于对贪心算法有个初步了解。 这道题的开篇向我们介绍了一个叫汉明距离的概念。 汉明距离指的就是两个相同长度的字符串的不同字符的个数。 例如&#xff0c;abc和acd&#xff0c;b与c不同&#xff0c;c与d不同&#xff0c;所以这两个…

小迪安全43WEB 攻防-通用漏洞任意文件下载删除重装敏感读取黑白审计

#知识点&#xff1a; 1、文件操作类安全问题 2、文件下载&删除&读取 3、白盒&黑盒&探针分析 #详细点&#xff1a; 文件读取&#xff1a;基本和文件下载利用类似 文件下载&#xff1a;利用下载获取源码或数据库配置文件及系统敏感文件为后续出思路 …

Java部署运维

1.docker Docker&#xff08;一&#xff09;&#xff1a;安装、命令、应用Docker(二)&#xff1a;数据卷、Dockefile、Docker-composeDocker(三) 通过gitlab部署CICD Docker超详细教程——入门篇实战 Docker教程 2.nginx 3.keepalived 4.k8s 5.jekenis

springboot中配置前后端日期格式转化

一、说在前面 springboot的自动注入中内嵌了格式转化器,如果不做配置按照系统的默认时间格式请求和响应数据。 形如&#xff1a;Wed Mar 20 10:32:29 CST 2024 也就是说如果请求响应的数据和这个格式一样&#xff0c;就能成功&#xff0c;就不会报404 内嵌格式转化器&#…

SpringCloud Alibaba 入门简介

一、前言 接下来是开展一系列的 SpringCloud 的学习之旅&#xff0c;从传统的模块之间调用&#xff0c;一步步的升级为 SpringCloud 模块之间的调用&#xff0c;此篇文章为第十一篇&#xff0c;即介绍 SpringCloud Alibaba 的入门信息。 二、出现的原因 Spring Cloud Netflix…

视频素材库哪里找?推荐几个高质量的无水印视频素材网

在寻找创意优质素材的道路上&#xff0c;拥有一个好的导航仪至关重要。这不仅仅是关于找到一张图片或一个视频&#xff0c;而是关于发现那些能让你的项目闪耀的宝藏。今天&#xff0c;我将混合介绍国内外的素材网站&#xff0c;旨在为你提供一个全面的视角&#xff0c;同时尽量…

安卓开发日记:实现APP重启逻辑,适用于热更后重启游戏进行加载

可根据合适的弹窗搭配使用重启逻辑&#xff0c;建议使用在热更包加载后使用&#xff0c;帮助部分热更后未及时生效的逻辑范围首先&#xff0c;在逻辑调用Activity类中创建一个成员变量&#xff0c;给后续逻辑接口直接使用 如下 public class MainActivity extends Activity {…

【学习】CMMI评估认证的意义和需要注意的问题

​ CMMI认证是软件能力成熟度集成模型&#xff0c;是软件行业中的一种质量管理体系&#xff0c;旨在评估软件开发组织的成熟度和能力&#xff0c;以帮助企业提高软件质量、降低成本、控制风险&#xff0c;并获得更好的商业效益。 一、CMMI评估认证的意义 1. 提高软件质量&am…