【AI生成文章】flutter ChangeNotifierProvider 实用场景举例

内容由Ai 大模型生成,不能完全保障真实

ChangeNotifierProvider 是 Flutter 中一个非常实用的工具,用于在应用程序中管理和传递状态。以下是一些实用的场景举例:

1. 用户信息管理

在应用程序中,用户信息(如用户名、头像、偏好设置等)通常需要在多个页面中访问和展示。使用 ChangeNotifierProvider,你可以创建一个 UserInfoModel 类,继承自 ChangeNotifier,用于管理用户信息。然后,你在应用程序的顶层使用 ChangeNotifierProvider 包裹,这样任何需要访问用户信息的组件都可以通过 ConsumerSelector 来获取和监听用户信息的变化。

class UserInfoModel extends ChangeNotifier {String _username;String _avatarUrl;String get username => _username;String get avatarUrl => _avatarUrl;void updateUserInfo(String username, String avatarUrl) {_username = username;_avatarUrl = avatarUrl;notifyListeners();}
}
void main() {runApp(ChangeNotifierProvider(create: (context) => UserInfoModel(),child: MaterialApp(home: MyHomePage(),),),);
}
class MyUserProfile extends StatelessWidget {Widget build(BuildContext context) {final userInfo = Provider.of<UserInfoModel>(context);return Column(children: [Text(userInfo.username),Image.network(userInfo.avatarUrl),],);}
}

2. 购物车状态管理

在电子商务应用程序中,购物车的状态(如添加商品、删除商品、修改商品数量等)需要在多个页面中保持同步。使用 ChangeNotifierProvider,你可以创建一个 CartModel 类来管理购物车状态。然后,你在应用程序的顶层使用 ChangeNotifierProvider 包裹,这样任何需要访问购物车状态的组件都可以通过 ConsumerSelector 来获取和监听购物车状态的变化。

class CartModel extends ChangeNotifier {final List _cartItems = [];List get cartItems => _cartItems;void addToCart(String itemId) {_cartItems.add(itemId);notifyListeners();}void removeFromCart(String itemId) {_cartItems.remove(itemId);notifyListeners();}
}
void main() {runApp(ChangeNotifierProvider(create: (context) => CartModel(),child: MaterialApp(home: MyShoppingPage(),),),);
}
class MyShoppingCart extends StatelessWidget {Widget build(BuildContext context) {final cart = Provider.of<CartModel>(context);return ListView.builder(itemCount: cart.cartItems.length,itemBuilder: (context, index) {return ListTile(title: Text(cart.cartItems[index]),);},);}
}

3. 应用主题切换

在应用程序中,允许用户切换主题(如亮色主题和暗色主题)是一个常见的功能。使用 ChangeNotifierProvider,你可以创建一个 ThemeModel 类来管理当前主题。然后,你在应用程序的顶层使用 ChangeNotifierProvider 包裹,这样任何需要根据主题变化的组件都可以通过 ConsumerSelector 来获取和监听主题的变化。

class ThemeModel extends ChangeNotifier {ThemeData _themeData;ThemeData get themeData => _themeData;void setTheme(ThemeData theme) {_themeData = theme;notifyListeners();}
}
void main() {runApp(ChangeNotifierProvider(create: (context) => ThemeModel(),child: MaterialApp(theme: ThemeData.light(),darkTheme: ThemeData.dark(),themeMode: ThemeMode.system,home: MyThemePage(),),),);
}
class MyThemeSwitcher extends StatelessWidget {Widget build(BuildContext context) {final theme = Provider.of<ThemeModel>(context);return Switch(value: theme.themeData == ThemeData.dark(),onChanged: (value) {if (value) {theme.setTheme(ThemeData.dark());} else {theme.setTheme(ThemeData.light());}},);}
}

这些场景展示了 ChangeNotifierProvider 如何在 Flutter 应用程序中用于状态管理和传递。通过使用 ChangeNotifierProvider,你可以轻松地在应用程序的不同部分共享和同步状态,同时保持代码的整洁和组织。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/764601.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【Android】【Bluetooth Stack】蓝牙音乐协议分析之音频控制与信息加载(超详细)

1. 精讲蓝牙协议栈(Bluetooth Stack):SPP/A2DP/AVRCP/HFP/PBAP/IAP2/HID/MAP/OPP/PAN/GATTC/GATTS/HOGP等协议理论 2. 欢迎大家关注和订阅,【蓝牙协议栈】和【Android Bluetooth Stack】专栏会持续更新中.....敬请期待! 目录 1. 音乐信息加载 1.1 歌曲信息 1.1.1 key_c…

selenium自动化登录模块HTMLTestRunner测试报告

1.下载HTMLTestRunner.py放到python的Lib目录下&#xff0c;python3之后的&#xff0c;文件要修改以下内容&#xff1a; 第94行&#xff0c;将import StringIO修改成import io 第539行&#xff0c;将self.outputBuffer StringIO.StringIO()修改成self.outputBuffer io.Strin…

【微服务】微服务架构的最佳实践总结!

目录 推荐超级课程: Docker快速入门到精通Kubernetes入门到大师通关课AWS云服务快速入门实战构建和管理微服务是一项艰巨的任务。这是因为微服务就像多个并行的整体应用程序,它们都必须处于同步通信和并发运行时间。因此,在设计和构建它们时考虑并应用最佳实践非常重要。以下…

C++ —— 日期计算器

1. 头文件 #pragma once #include <iostream> using namespace std;class Date { public:Date(int year 1, int month 1, int day 1);int GetMonthDay();bool operator>(const Date& d) const;bool operator>(const Date& d)const;bool operator<(c…

单例模式:双重效验锁的懒汉实现方式

单例模式&#xff1a;双重效验锁的懒汉实现方式 单例模式饿汉模式实现懒汉模式实现改进1 (创建多个实例)改进2 (性能比较低)改进3 (volatile禁止指令重排序) 单例模式 单例模式顾名思义就是指实例化一个对象&#xff0c;通过把构造方法私有化来禁止创建实例。 饿汉模式实现 饿汉…

GPU算力池管理工具Determined AI部署与使用教程(2024.03)

1. 概念 1.1 什么是Determined&#xff1f; Determined AI 是一个全功能的深度学习平台&#xff0c;兼容 PyTorch 和 TensorFlow。它主要负责以下几个方面&#xff1a; 分布式训练&#xff1a;Determined AI 可以将训练工作负载分布在多个 GPU&#xff08;可能在多台计算机上…

大模型开发中使用prompt提示最佳实践

在大型模型开发中&#xff0c;使用prompt&#xff08;提示&#xff09;是一种指导模型生成所需输出的方法。以下是在使用prompt时的一些最佳实践&#xff1a; 1、明确的提示&#xff1a;确保prompt提供了明确、清晰的指导&#xff0c;以便模型理解所需生成的内容。避免模棱两可…

IPP-7010 表面贴装 90 度混合耦合器

IPP-7010 表面贴装 90 度混合耦合器 IPP-7010 是一款表面贴装 90 度混合耦合器&#xff0c;工作频率为 800 至 2500 MHz&#xff08;0.8 至 2.5 GHz&#xff09;&#xff0c;平均额定功率为 200 瓦。IPP-7010 采用 0.40 x 1.80 英寸表面贴装封装。IPP-7010的幅度平衡小于0.6dB&…

鸿蒙预览报错 Only files in a module can be previewed

HarmonyOS第一课下载的源码无法运行&#xff0c;也无法预览&#xff0c;报错如题。 解决&#xff1a; 1、在预览页如“index.ets”文件下预览。 2、如果在通知栏看到如图提示&#xff0c;可看出是ohos/hvigor-ohos-plugin插件版本的问题&#xff0c;可点击蓝色解决方案同步并导…

HTTP Header Fields

HTTP&#xff08;超文本传输协议&#xff09;中包含多种类型的头部字段&#xff08;Header Fields&#xff09;&#xff0c;以下是常见的HTTP头部字段及其作用&#xff1a; ### 通用头字段&#xff08;General Header Fields&#xff09; - **Cache-Control**: 控制缓存行为&a…

python 函数(解包**、互相调用、作用域、函数的封装、内置函数:eval()、zip()、文件处理open())

函数解包 """ 1、函数的注释&#xff1a;参数和返回值 在注释里可以自动添加显示&#xff0c;只需手动加说明。2、函数的解包【拆包】&#xff1a;函数的参数要传递数据有多个值的时候&#xff0c;中间步骤拿到数据 保存在元组或者列表 或者字典里。 - 传递参数…

活用 C语言之union的精妙之用

一、union的基本定义 Union的中文叫法又被称为共用体、联合或者联合体。它的定义方式与结构体相同,但意义却与结构体完全不同。下面是union的定义格式: union 共用体名 {成员列表}共用体变量名;它与结构体的定义方式相同,但区别在于共用体中的成员的起始地址都是相同的,…

【理解机器学习算法】之Clustering算法(DBSCAN)

DBSCAN&#xff08;基于密度的空间聚类应用噪声&#xff09;是数据挖掘和机器学习中一个流行的聚类算法。与K-Means这样的划分方法不同&#xff0c;DBSCAN特别擅长于识别数据集中各种形状和大小的聚类&#xff0c;包括存在噪声和离群点的情况。 以下是DBSCAN工作原理的概述&am…

centos7 安装php82

安装epel扩展源 yum -y install epel-release vim 镜像地址: https://mirrors.aliyun.com/remi/ #这个阿里源专门提供了php的各种版本 下载镜像&#xff08;如果epel扩展源包含php8.2版本&#xff0c;可不需要下载此镜像。建议下载&#xff0c;百利无一害&#xff09; …

KubeSphere的基本使用操作

KubeSphere的基本使用操作 基本使用用户角色创建企业空间创建项目 创建应用创建密钥创建MySQL密钥创建WordPress密钥 创建存储卷创建MySQL存储卷创建Wordpress存储卷 添加组件服务类型添加MySQL组件添加WordPress组件 访问Wordpress 基本使用 用户角色 KubeSphere 中的权限控制…

FloodFill算法——岛屿数量

文章目录 题目解析算法解析代码解析 题目解析 岛屿数量 题目依旧是熟悉的配方&#xff0c;熟悉的味道&#xff0c;还是那个0还是那个1还是那个二维矩阵&#xff0c;这时候BFS和DFS闻着味就来了&#xff0c;我们来看一下这个题目&#xff0c;这个题目也很容易理解如下图有一个…

【每日一问】IOS手机上Charles证书过期怎么办?

1、如何查看证书是否过期? 设置>通用>VPN与设备管理 2、在Charles中重置证书 步骤1&#xff1a;重置证书 Help>SSL Proxying>Reset Charles Root Certificate… 步骤2&#xff1a;在浏览器中&#xff0c;下载证书 首先&#xff0c;手机连上代理&#xff0c;然…

qt+ffmpeg 实现音视频播放(三)之视频播放

一、视频播放流程 &#xff08;PS&#xff1a;视频的播放流程跟音频的及其相似&#xff01;&#xff01;&#xff09; 1、打开视频文件 通过 avformat_open_input() 打开媒体文件并分配和初始化 AVFormatContext 结构体。 函数原型如下&#xff1a; int avformat_open_inpu…

Sphinx使用md文档构建失败

​使用 sphinx 构建文档&#xff0c;有时候已经放置好了文档却无法读入生成。 解决方案 在环境中下载安装好相应的库: pip install sphinx_markdown_tablespip install m2r打开生成的 source目录下的 conf.py&#xff0c;文件&#xff0c;在文件中加入&#xff1a; extensio…

19.C++20中的std::latch和std::barrier

文章目录 线程闩std::latch和线程卡std::barrier线程闩std::latch线程卡std::barrier的使用线程闩std::latch和线程卡std::barrier的区别reference 欢迎访问个人网络日志&#x1f339;&#x1f339;知行空间&#x1f339;&#x1f339; 线程闩std::latch和线程卡std::barrier …