flutter provider状态管理使用
在 Flutter 中,Provider 是一个轻量级且易于使用的状态管理工具,它基于 InheritedWidget,并提供了一种高效的方式来管理和共享应用中的状态。相比其他复杂的状态管理方案(如 Bloc 或 Riverpod),Provider 更加简单直观,适合中小型项目。
以下是一个完整的示例,展示如何使用 Provider 进行状态管理。
1. 添加依赖
在 pubspec.yaml 文件中添加 provider 依赖:
dependencies:flutter:sdk: flutterprovider: ^6.0.0 # 确保使用最新版本
然后运行以下命令安装依赖:
flutter pub get
2. 创建数据模型和状态管理类
我们创建一个简单的计数器示例,展示如何通过 Provider 管理状态。
定义 Counter 模型
创建一个文件 counter_provider.dart:
import 'package:flutter/material.dart';// 定义一个 ChangeNotifier 类来管理状态
class Counter with ChangeNotifier {int _count = 0;// 获取当前计数值int get count => _count;// 增加计数值void increment() {_count++;notifyListeners(); // 通知监听器更新 UI}// 减少计数值void decrement() {_count--;notifyListeners(); // 通知监听器更新 UI}
}
ChangeNotifier是Provider提供的一个基类,用于管理状态并通知监听器。- 调用
notifyListeners()方法会触发所有监听该状态的 Widget 更新。
3. 设置 Provider
在应用的顶层设置 Provider,以便在整个应用中访问状态。
修改 main.dart
创建一个文件 main.dart:
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'counter_provider.dart'; // 导入状态管理类void main() {runApp(// 使用 ChangeNotifierProvider 包裹整个应用ChangeNotifierProvider(create: (context) => Counter(), // 初始化状态管理对象child: const MyApp(),),);
}class MyApp extends StatelessWidget {const MyApp({Key? key}) : super(key: key);Widget build(BuildContext context) {return MaterialApp(title: 'Flutter Provider 示例',theme: ThemeData(primarySwatch: Colors.blue),home: const CounterPage(),);}
}class CounterPage extends StatelessWidget {const CounterPage({Key? key}) : super(key: key);Widget build(BuildContext context) {return Scaffold(appBar: AppBar(title: const Text('Provider 状态管理')),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[const Text('当前计数值:',style: TextStyle(fontSize: 20),),// 使用 Consumer 监听状态变化Consumer<Counter>(builder: (context, counter, child) {return Text('${counter.count}',style: Theme.of(context).textTheme.headlineMedium,);},),],),),floatingActionButton: Column(mainAxisAlignment: MainAxisAlignment.end,children: [FloatingActionButton(onPressed: () {// 获取状态管理对象并调用方法Provider.of<Counter>(context, listen: false).increment();},child: const Icon(Icons.add),),const SizedBox(height: 10),FloatingActionButton(onPressed: () {// 获取状态管理对象并调用方法Provider.of<Counter>(context, listen: false).decrement();},child: const Icon(Icons.remove),),],),);}
}
4. 代码说明
-
ChangeNotifierProvider:- 在
main.dart中,使用ChangeNotifierProvider包裹整个应用。 create回调函数用于初始化状态管理对象(这里是Counter)。
- 在
-
Consumer:Consumer是一个高效的监听器,用于监听状态的变化并更新 UI。- 在
builder方法中,可以访问到最新的状态值(counter.count)。
-
Provider.of:- 使用
Provider.of<Counter>(context, listen: false)获取状态管理对象。 - 设置
listen: false表示不监听状态变化(通常用于触发事件的地方,如按钮点击)。
- 使用
-
状态更新:
- 调用
increment()或decrement()方法时,notifyListeners()会通知所有监听器重新构建相关的 Widget。
- 调用
5. 测试与运行
运行项目后,你会看到一个简单的计数器界面:
- 点击 “+” 按钮,计数值增加。
- 点击 “-” 按钮,计数值减少。
6. 可选优化
- 多状态管理:如果需要管理多个状态,可以使用
MultiProvider将多个Provider组合在一起。 - 异步数据加载:可以在
Provider中处理异步操作(如网络请求),并通过状态变量(如isLoading)控制加载状态。 - Scoped Provider:如果某些状态只在特定页面中使用,可以将
Provider包裹在该页面的 Widget 树中,而不是整个应用。
示例:使用 MultiProvider
void main() {runApp(MultiProvider(providers: [ChangeNotifierProvider(create: (_) => Counter()),ChangeNotifierProvider(create: (_) => AnotherModel()),],child: const MyApp(),),);
}
7. 总结
Provider 是一种简单而强大的状态管理工具,适合大多数 Flutter 应用场景。通过结合 ChangeNotifier 和 Consumer,你可以轻松实现状态的集中管理和局部更新。
相关文章:
flutter provider状态管理使用
在 Flutter 中,Provider 是一个轻量级且易于使用的状态管理工具,它基于 InheritedWidget,并提供了一种高效的方式来管理和共享应用中的状态。相比其他复杂的状态管理方案(如 Bloc 或 Riverpod),Provider 更…...
1. 标准库的强依赖(核心原因)
1. 标准库的强依赖(核心原因) 容器操作(如 std::vector 扩容) 当标准库容器(如 std::vector)需要重新分配内存时,它会尝试移动现有元素到新内存,而非拷贝(为了性能&…...
USB3.0走线注意事项和其中的协议
USB3.0走线的要求: 1、USB要走差分,阻抗控制为90欧姆,并包地处理,总长度最好不要超过1800mil. 2、尽可能缩短走线长度,优先考虑对高速USB差分(RX、TX差分)的布线,USB差分走线在走线…...
【Linux】iptables命令的基本使用
语法格式 iptables [-t 表名] 管理选项 [链名] [条件匹配] [-j 目标动作或跳转]注意事项 不指定表名时,默认使用 filter 表不指定链名时,默认表示该表内所有链除非设置规则链的缺省策略,否则需要指定匹配条件 设置规则内容 -A:…...
QML 菜单控件:MenuBar、MenuBarItem、Menu、MenuItem层级关系和用法
目录 引言相关阅读关于MenuBarItem核心代码1. 主菜单栏 (MenuBar.qml)2. 主页面,包含右键菜单 (MainPage.qml)3. 主界面绑定 (Main.qml)整体结构 运行效果总结工程下载 引言 在 GUI 开发中,菜单是用户交互的核心组件。QML 提供了一套灵活的菜单控件&…...
设计模式简述(十二)策略模式
策略模式 描述基本使用使用传统策略模式的缺陷以及规避方法 枚举策略描述基本使用使用 描述 定义一组策略,并将其封装起来到一个策略上下文中。 由调用者决定应该使用哪种策略,并且可以动态替换 基本使用 定义策略接口 public interface IStrategy {…...
Telegram机器人开发
注册机器人 :使用Botfather 按照提示快速注册,会得到一串密钥 格式类似 7878875019:BAGQ9AihJyE5jmSoWMt4O1j1CQThjfwR0nk # !/usr/bin/python3 # -*- coding:utf-8 -*- """ author: JHC000abcgmail.com file: TelegramBot.py time: 202…...
蓝桥杯嵌入式第十四届模拟二
一.LED 先配置LED的八个引脚为GPIO_OutPut,锁存器PD2也是,然后都设置为起始高电平,生成代码时还要去解决引脚冲突问题 二.按键 按键配置,由原理图按键所对引脚要GPIO_Input 生成代码,在文件夹中添加code文件夹,code中添加fun.c、fun.h、headfile.h文件,去资源包中把lc…...
java发送http请求
常用的方式 jdk自带的工具类apache的httpclient工具类spring的resttemplate工具类 如果是springboot项目,推荐resttemplate,其它项目推荐httpclient httpclient教程 httpclient教程...
Qt 入门 1 之第一个程序 Hello World
Qt 入门1之第一个程序 Hello World 直接上操作步骤从头开始认识,打开Qt Creator,创建一个新项目,并依次执行以下操作 在Qt Creator中,一个Kits 表示一个完整的构建环境,包括编译器、Qt版本、调试器等。在上图中可以直…...
架构思维: 全链路日志深度解析
文章目录 引言:微服务时代的日志挑战一、业务痛点与需求分析二、技术选型的六维评估模型1. 标准化支持 OpenTracing2. 存储扩展性3. 性能损耗4. 功能完备性5. 侵入性控制6. 社区生态 三、SkyWalking落地实践与调优1. 核心架构解析2. 关键配置示例: 采样率…...
PHP 项目搭建 ELK 日志监控体系完整指南
ELK (Elasticsearch Logstash Kibana) 是当前最流行的日志管理解决方案之一。下面详细介绍如何为 PHP 项目搭建完整的 ELK 日志监控体系。 一、基础架构组成 PHP应用 → Filebeat → Logstash → Elasticsearch → Kibana(可选) ↗ 二、环境准备 1. 服务器要求 建议独立服…...
唯美社区源码AM社区同款源码
源码介绍 唯美社区源码AM社区同款源码 后端修改application.properties文件内容为你的数据库 前端修改/config/config.js文件内容为你的后端地址 这两个文件里要修改的地方我已经用中文标注出来了 截图 源码免费下载 唯美社区源码AM社区同款源码...
《野史未必假》王磊
文章目录 前言一、禅让制的真相:让了,又没有完全让禅让制的真相尧舜禹之间的“禅让”实际上是一场权力斗争 二、美女间谍的下落:西施和范蠡终成眷属了吗范蠡的逃亡“美人计”的真相 三、“背叛”的名将:魏延真的有“反骨”吗?“子…...
Redis 热key问题怎么解决?
Redis 热 Key 问题分析与解决方案 热 Key(Hot Key)是指被高频访问的某个或多个 Key,导致单个 Redis 节点负载过高,可能引发性能瓶颈甚至服务崩溃。以下是常见原因及解决方案: 1. 热 Key 的常见原因 突发流量:如明星八卦、秒杀商品、热门直播等场景。缓存设计不合理:如全…...
定制一款国密浏览器(3):修改浏览器应用程序安装路径
在上一章中介绍了如何修改 deb 包的包名,这一章讲一下如何修改浏览器应用程序安装路径。 chromium deb 包将程序文件安装在 /usr/share/chromium 下,但在很多系统中(比如统信 UOS 和 麒麟系统),规范要求应用程序安装在 /opt/apps 下。此外,对一些不可变系统(比如 deepi…...
3. go-zero中如何使用redis
问题 go-zero项目相关文档中redis是这样配置的: Name: account.rpc ListenOn: 0.0.0.0:8080 Etcd:Hosts:- 127.0.0.1:2379Key: account.rpcMysql:Host: xxxx:3306User: rootPass: xxxData: mall-userCharset: utf8mb4Cache: - Host: 192.168.145.10:6379Type: nod…...
cpp自学 day19(多态)
一、基本概念 同一操作作用于不同的对象,产生不同的执行结果 👉 就像「按F1键」:在Word弹出帮助文档,在PS弹出画笔设置,同一个按键触发不同功能 (1)多态类型 类型实现方式绑定时机静态多态…...
【算法/c++】利用中序遍历和后序遍历建二叉树
目录 题目:树的遍历前言题目来源树的数组存储基本思想存储规则示例 建树算法关键思路代码总代码 链表法 题目:树的遍历 前言 如果不是完全二叉树,使用数组模拟树,会很浪费空间。 题目来源 本题来自 PTA 天梯赛。 题目链接: 树…...
基于论文的大模型应用:基于SmartETL的arXiv论文数据接入与预处理(一)
1. 背景 arXiv简介(参考DeepSeek大模型生成内容): arXiv(发音同“archive”,/ˈɑːrkaɪv/)是一个开放的学术预印本平台,主要用于研究人员分享和获取尚未正式发表或已完成投稿的学术论文。创…...
cpp经典数论问题
题目如下 思路 代码如下...
C++中如何比较两个字符串的大小--compare()函数实现
一、现在有一个问题描述:有两个字符串,要按照字典顺序比较它们的大小(注意所有的小写字母都大于所有的大写字母 )。 二、代码 #include <bits/stdc.h> using namespace std;int main() {string str1 "apple";…...
微软2025年AI技术深度解析:从多模态大模型到企业级代理服务
微软2025年AI技术深度解析:从多模态大模型到企业级代理服务 一、微软AI技术全景概览 在2025年的AI领域,微软通过Azure AI Foundry、多模态大模型、企业级AI代理三大核心技术,构建了覆盖开发、部署、应用全流程的AI生态体系。根据最新财报数…...
C++中的匿名函数
代码解析 auto getTicks [](QCPAxis *axis) -> QList<double> {QList<double> ticks;if(auto ticker static_cast<QCPAxisTickerFixed *>(axis->ticker().data())){double current axis->range().lower;const double step ticker->…...
浏览器 路由详解
Hash路由 URL 结构:http://example.com/#/path,# 后的部分称为哈希(Hash)。无刷新特性:浏览器不会将哈希部分发送到服务器,改变哈希值不会触发页面刷新。事件驱动:URL…...
Scala面向对象2
1. 抽象属性和方法:用 abstract 关键字定义抽象类,其中抽象属性无初始值,抽象方法无实现 。重写抽象方法需用 override ,重写抽象属性时,可变属性用 var ,不可变属性用 val 。 匿名子类:和 Jav…...
【FPGA基础学习】状态机思想实现流水灯
目录 一、用状态机实现LED流水灯1.状态机思想简介1. 1基本概念1.2.核心要素1.3分类与模型 2.LED流水灯 二、CPLD与FPGA1.技术区别2.应用场景3.设计选择建议 三、HDLbits组合逻辑题目 一、用状态机实现LED流水灯 1.状态机思想简介 1. 1基本概念 状态机(Finite …...
HTML表单属性2
HTML5针对<input>添加了许多属性: autofocus属性 页面加载时自动聚焦到输入字段 <form action"action_page.php" >名字: <input type"text" name"fnam" autofocus><br>姓氏:<in…...
图片尺寸修改软件下载
【图片尺寸调整工具v1.0:高效便捷的图像处理助手】 图片尺寸调整工具v1.0是一款专为简化图像处理流程设计的轻量级软件,兼顾高效批量处理与个性化单图调整需求。该工具以"零学习成本"为核心设计理念,通过简洁直观的交互界面&#…...
202521 | 远程调用 | 注册中心
远程调用 1. 核心方案全景图 #mermaid-svg-f3oyP1p2P8a2lAuW {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-f3oyP1p2P8a2lAuW .error-icon{fill:#552222;}#mermaid-svg-f3oyP1p2P8a2lAuW .error-text{fill:#55222…...
