当前位置: 首页 > article >正文

3.2 原生方案

Flutter 提供了三种原生无需第三方依赖的状态管理方案分别适用于不同规模和场景。一、setState局部状态管理setState是 Flutter 最基础的状态管理方式适合管理单个 Widget 内的局部状态。1.1 基本用法classShoppingCartButtonextendsStatefulWidget{constShoppingCartButton({super.key});overrideStateShoppingCartButtoncreateState()_ShoppingCartButtonState();}class_ShoppingCartButtonStateextendsStateShoppingCartButton{int _itemCount0;bool _isAddingfalse;Futurevoid_addToCart()async{setState(()_isAddingtrue);try{awaitCartService.addItem();setState(()_itemCount);}finally{setState(()_isAddingfalse);}}overrideWidgetbuild(BuildContextcontext){returnBadge(label:Text($_itemCount),isLabelVisible:_itemCount0,child:IconButton(icon:_isAdding?constSizedBox(width:20,height:20,child:CircularProgressIndicator(strokeWidth:2),):constIcon(Icons.shopping_cart),onPressed:_isAdding?null:_addToCart,),);}}1.2 ValueNotifier ValueListenableBuilder比 setState 更加精细避免整个 Widget 重建classCounterPageextendsStatelessWidget{final_counterValueNotifierint(0);CounterPage({super.key});overrideWidgetbuild(BuildContextcontext){returnScaffold(body:Center(// 只有 ValueListenableBuilder 内部重建不影响整个页面child:ValueListenableBuilderint(valueListenable:_counter,builder:(context,value,child){returnText(Count:$value,style:constTextStyle(fontSize:24));},),),floatingActionButton:FloatingActionButton(onPressed:()_counter.value,child:constIcon(Icons.add),),);}}1.3 setState 的正确姿势// ✅ 只在 setState 中修改状态setState((){_isLoadingtrue;_errorMessagenull;});// ❌ 错误在 setState 外修改可能导致 UI 不更新_isLoadingtrue;// 没有通知 Flutter 重建setState((){});// 空 setState不推荐// ✅ 避免在 setState 中做耗时操作setState((){// 只做赋值不做网络请求或复杂计算_datanewData;});二、InheritedWidget 进阶跨组件共享数据InheritedWidget是 Flutter 状态共享的底层机制Provider 等第三方框架都基于它实现。2.1 基本实现// 1. 定义 InheritedWidgetclassThemeInheritedextendsInheritedWidget{finalThemeDatathemeData;finalVoidCallbacktoggleTheme;constThemeInherited({super.key,requiredthis.themeData,requiredthis.toggleTheme,requiredsuper.child,});// 提供 of 方法方便子 Widget 获取staticThemeInheritedof(BuildContextcontext){finalresultcontext.dependOnInheritedWidgetOfExactTypeThemeInherited();assert(result!null,No ThemeInherited found in context);returnresult!;}// 决定何时通知依赖的子 Widget 更新overrideboolupdateShouldNotify(ThemeInheritedoldWidget){returnthemeData!oldWidget.themeData;}}// 2. 在祖先 Widget 中提供classAppRootextendsStatefulWidget{overrideStateAppRootcreateState()_AppRootState();}class_AppRootStateextendsStateAppRoot{ThemeData_themeThemeData.light();void_toggleTheme(){setState((){_theme_theme.brightnessBrightness.light?ThemeData.dark():ThemeData.light();});}overrideWidgetbuild(BuildContextcontext){returnThemeInherited(themeData:_theme,toggleTheme:_toggleTheme,child:MaterialApp(theme:_theme,home:constHomePage()),);}}// 3. 在任意子 Widget 中消费classThemeToggleButtonextendsStatelessWidget{overrideWidgetbuild(BuildContextcontext){finalinheritedThemeInherited.of(context);returnSwitch(value:inherited.themeData.brightnessBrightness.dark,onChanged:(_)inherited.toggleTheme(),);}}2.2 maybeOf vs of// of找不到时直接 assert 报错推荐必须依赖时使用staticMyDataof(BuildContextcontext)context.dependOnInheritedWidgetOfExactTypeMyData()!;// maybeOf找不到时返回 null可选依赖时使用staticMyData?maybeOf(BuildContextcontext)context.dependOnInheritedWidgetOfExactTypeMyData();三、Provider 体系Provider 是 Flutter 官方推荐的状态管理方案基于 InheritedWidget提供更简洁的 API。3.1 安装dependencies:provider:^6.1.03.2 ChangeNotifier Provider第一步定义 ChangeNotifier 模型classCartModelextendsChangeNotifier{finalListCartItem_items[];ListCartItemgetitemsList.unmodifiable(_items);// 只读访问intgetitemCount_items.length;doublegettotalPrice_items.fold(0,(sum,item)sumitem.price*item.quantity);voidaddItem(Productproduct){finalindex_items.indexWhere((item)item.productIdproduct.id);if(index0){_items[index]_items[index].copyWith(quantity:_items[index].quantity1,);}else{_items.add(CartItem.fromProduct(product));}notifyListeners();// 通知所有监听者重建}voidremoveItem(StringproductId){_items.removeWhere((item)item.productIdproductId);notifyListeners();}voidclear(){_items.clear();notifyListeners();}}第二步在 Widget 树中注入// 单个 ProviderChangeNotifierProviderCartModel(create:(_)CartModel(),child:constMyApp(),)// 多个 ProviderMultiProvider(providers:[ChangeNotifierProvider(create:(_)CartModel()),ChangeNotifierProvider(create:(_)UserModel()),ChangeNotifierProvider(create:(_)ThemeModel()),// Provider.value共享已有实例ProviderApiService.value(value:ApiService.instance),],child:constMyApp(),)第三步在子 Widget 中消费// 方式一Provider.of会触发整个 Widget 重建Widgetbuild(BuildContextcontext){finalcartProvider.ofCartModel(context);returnText(共${cart.itemCount}件商品);}// 方式二context.watch效果同上语法更简洁Widgetbuild(BuildContextcontext){finalcartcontext.watchCartModel();returnText(共${cart.itemCount}件商品);}// 方式三context.read仅读取不监听不触发重建ElevatedButton(onPressed:()context.readCartModel().addItem(product),child:constText(加入购物车),)// 方式四context.select精确监听特定字段Widgetbuild(BuildContextcontext){// 只有 itemCount 变化才重建totalPrice 变化不触发finalcountcontext.selectCartModel,int((cart)cart.itemCount);returnText(共$count件);}3.3 Consumer提供更细粒度的重建控制Scaffold(appBar:AppBar(title:constText(购物车),actions:[// Consumer只有 CartModel 变化时这里才重建ConsumerCartModel(builder:(context,cart,child){returnBadge(label:Text(${cart.itemCount}),child:child!,);},child:constIcon(Icons.shopping_cart),// 静态子 Widget不随状态重建),],),body:ConsumerCartModel(builder:(context,cart,_){if(cart.items.isEmpty){returnconstEmptyCartWidget();}returnCartItemList(items:cart.items);},),)3.4 Selector比 Consumer 更精细只监听状态的部分字段// 只有 totalPrice 变化才重建此组件SelectorCartModel,double(selector:(_,cart)cart.totalPrice,builder:(context,totalPrice,_){returnText(总计¥${totalPrice.toStringAsFixed(2)},style:Theme.of(context).textTheme.titleLarge,);},)// 监听多个字段SelectorCartModel,(int,double)(selector:(_,cart)(cart.itemCount,cart.totalPrice),builder:(context,(count,price),_){returnText($count件¥${price.toStringAsFixed(2)});},)3.5 ProxyProvider派生状态MultiProvider(providers:[ProviderApiService(create:(_)ApiService()),// ProductRepository 依赖 ApiServiceProxyProviderApiService,ProductRepository(update:(_,apiService,__)ProductRepository(apiService),),// 监听用户状态变化派生出相关数据ChangeNotifierProxyProviderUserModel,CartModel(create:(_)CartModel(),update:(_,user,cart)cart!..updateUser(user),),],child:constMyApp(),)小结方案适用场景重建粒度复杂度setState单 Widget 内的局部状态整个 Widget最低ValueNotifier局部需要精细控制仅 ValueListenableBuilder低InheritedWidget框架级数据共享依赖的子 Widget中Provider.of全局状态消费整个 Widget中Consumer局部重建Consumer 内部中Selector精确字段监听仅选择字段变化时中 下一节3.3 第三方框架GetX / Riverpod / Bloc

相关文章:

3.2 原生方案

Flutter 提供了三种原生(无需第三方依赖)的状态管理方案,分别适用于不同规模和场景。一、setState:局部状态管理 setState 是 Flutter 最基础的状态管理方式,适合管理单个 Widget 内的局部状态。 1.1 基本用法 class S…...

Harness Engineering:智能体任务依赖管理优化

Harness Engineering:智能体任务依赖管理优化 引言:智能体时代的任务编排挑战 在人工智能技术飞速发展的今天,我们正见证着从单一AI模型向多智能体协作系统的范式转变。从自动驾驶车队到智能工厂,从推荐系统到科研自动化,智能体正在以前所未有的规模和复杂度参与到各类任…...

Arduino工业泵Modbus驱动库:语义化控制与高可靠通信

1. 项目概述iarduino_MB_Pump是一款专为工业泵类执行设备设计的嵌入式 Modbus 通信驱动库,面向 Arduino 及兼容平台(如 STM32duino、ESP32-Arduino)提供轻量级、高可靠性的 Modbus RTU/ASCII 协议栈封装。该库不依赖操作系统,可直…...

Kreuzberg PDF层次结构检测:基于K-means聚类的智能文档结构分析

Kreuzberg PDF层次结构检测:基于K-means聚类的智能文档结构分析 【免费下载链接】kreuzberg A polyglot document intelligence framework with a Rust core. Extract text, metadata, images, and structured information from PDFs, Office documents, images, an…...

彻底告别OpenClaw使用焦虑:我给他装上了“透视眼”和“批量克隆模组凡

指令替换 项目需求:将加法指令替换为减法 项目目录如下 /MyProject ├── CMakeLists.txt # CMake 配置文件 ├── build/ #构建目录 │ └── test.c #测试编译代码 └── mypass2.cpp # pass 项目代码 一,测试代码示例 test.c // test.c #includ…...

SenseVoice-Small ONNX酿酒工艺:发酵语音→糖度+温度+时间结构化记录

SenseVoice-Small ONNX酿酒工艺:发酵语音→糖度温度时间结构化记录 1. 引言:从“听不清”到“记得清”的酿造革命 想象一下,你是一位酿酒师,正站在发酵车间里。耳边是发酵罐低沉的嗡鸣,空气里弥漫着谷物和酵母的混合…...

The Algorithms - PHP单元测试完全指南:如何为算法编写高质量测试用例

The Algorithms - PHP单元测试完全指南:如何为算法编写高质量测试用例 【免费下载链接】PHP All Algorithms implemented in PHP 项目地址: https://gitcode.com/gh_mirrors/php1/PHP 在软件开发中,单元测试是确保代码质量和稳定性的关键环节。对…...

Sentry实战:Vue项目前端监控的快速接入指南

1. 为什么你的Vue项目需要Sentry监控? 最近接手了一个线上Vue项目的维护工作,刚上线就遇到用户反馈页面白屏的问题。排查了半天才发现是某个异步加载的组件抛出了未捕获的异常。这种问题如果能在开发阶段发现当然最好,但现实是很多错误只有在…...

Arduino嵌入式状态机轻量库:零堆内存、确定性状态管理

1. 项目概述ArduinoStates是一个面向嵌入式状态机开发的轻量级辅助库,专为 Arduino 及兼容平台(如 ESP32、ESP8266、STM32(通过 Arduino Core)、nRF52 等)设计。其核心定位并非实现完整状态机框架(如 UML S…...

为什么f(x)=x sin(1/x)是一个偶函数,奇函数乘以 偶函数得到的是偶函数?

视频生成垂直校验是干嘛的?一个人在某个特定的时间点,只能出现在一个地方。如果你画出这个人的运动轨迹,它一定能通过垂线校验。 画一个圆 坐标在圆中心,用垂直线通过圆,然后标记出 通过圆半径3 内的两个点 导致不知道…...

somo完全指南:从零开始配置你的网络监控系统

somo完全指南:从零开始配置你的网络监控系统 【免费下载链接】somo A human-friendly alternative to netstat for socket and port monitoring on Linux and macOS. 项目地址: https://gitcode.com/gh_mirrors/somo/somo somo是一款人性化的网络监控工具&am…...

Java性能调优实战:如何用IBM Thread and Monitor Dump Analyzer快速定位死锁问题

Java性能调优实战:如何用IBM Thread and Monitor Dump Analyzer快速定位死锁问题 在分布式系统和高并发场景下,Java应用的线程死锁问题如同潜伏的暗礁,随时可能让整个系统陷入瘫痪。作为开发者,我们需要的不仅是一把螺丝刀&#x…...

在麒麟Kylin-Server-V10-SP3上搞定VMware Tools:从安装到解决‘Job failed’报错的完整指南

麒麟Kylin-Server-V10-SP3深度排错:VMware Tools服务启动失败全解析与实战修复 当你在麒麟Kylin-Server-V10-SP3系统上完成VMware Tools安装的最后一步,却突然遭遇"Job for vmware-tools.service failed"的红色报错时,那种挫败感我…...

Qwen3.5-2B效果展示:漫画分镜图识别+剧情连贯性分析真实案例

Qwen3.5-2B效果展示:漫画分镜图识别剧情连贯性分析真实案例 1. 模型简介 Qwen3.5-2B是一款轻量化多模态基础模型,属于Qwen3.5系列的小参数版本(20亿参数)。这款模型主打低功耗、低门槛部署,特别适配端侧和边缘设备&a…...

CNCjs高级配置技巧:从端口设置到远程访问

CNCjs高级配置技巧:从端口设置到远程访问 【免费下载链接】cncjs A web-based interface for CNC milling controller running Grbl, Marlin, Smoothieware, or TinyG. 项目地址: https://gitcode.com/gh_mirrors/cn/cncjs CNCjs是一款强大的基于Web的CNC控制…...

Contribute-To-This-Project项目深度解析:为什么这是最适合新手的开源入门项目

Contribute-To-This-Project项目深度解析:为什么这是最适合新手的开源入门项目 【免费下载链接】Contribute-To-This-Project This project is waiting for your contribution. If you have never contributed code on GitHub before, this is the project to get y…...

STM32F042轻量级内建调试工具DEBUG_F042F6P6

1. 项目概述DEBUG_F042F6P6是一个面向 STM32F042F6P6 微控制器的轻量级、可复用调试工具集,专为资源受限的 Cortex-M0 嵌入式系统设计。该工具并非通用型调试器(如 ST-Link 或 J-Link),而是一套嵌入在目标固件内部的运行时诊断子系…...

Heltec ESP32 OLED显示库深度解析与工程实践

1. Heltec ESP32 OLED显示库技术解析与工程实践 Heltec ESP32系列开发板(如WiFi Kit 32、WiFi Kit 8、ESP32-LORA-V2等)因其集成SSD1306 OLED显示屏、LoRa模块、USB转串口芯片及丰富外设接口,成为物联网终端、低功耗传感器节点和教学实验平台…...

AI编程实战:从零到一搭建全栈项目潜

1. 核心概念 在 Antigravity 中,技能系统分为两层: Skills (全局库):实际的代码、脚本和指南,存储在系统级目录(如 ~/.gemini/antigravity/skills)。它们是“能力”的本体。 Workflows (项目级)&#xff1a…...

破解数字谜题:xyz+yzz=532

求x y z的值。已知xyzyzz532,其中xyz 和yzz分别表示一个三位数。#include <stdio.h>int main() {int x,y,z;printf("求x y z的值:\n");for(x1;x<9;x){for(y0;y<9;y){for(z0;z<9;z){if(100*x 110*y 12*z 532){printf("输出:\nx%d y%d z%d\n&quo…...

C语言实现:特定九九乘法表全解析

九九乘法表&#xff0c;输出如下格式的九九乘法表 #include <stdio.h> int main() { printf("九九乘法表&#xff1a;\n"); int i,j; for(i1;i<9;i) { for(j1;j<9;j) { printf("%d*%d%d ",i,j,i…...

云容笔谈保姆级教程:水墨UI中‘朱砂红印’触发机制与生成稳定性保障

云容笔谈保姆级教程&#xff1a;水墨UI中朱砂红印触发机制与生成稳定性保障 1. 教程概述与学习目标 云容笔谈是一款专注于东方美学风格的影像创作平台&#xff0c;通过先进的AI技术将现代算法与古典意境完美融合。本教程将重点讲解系统中最具特色的"朱砂红印"触发机…...

Alpamayo-R1-10B高算力适配:TensorRT加速与推理延迟优化实践

Alpamayo-R1-10B高算力适配&#xff1a;TensorRT加速与推理延迟优化实践 1. 项目背景与技术挑战 Alpamayo-R1-10B作为自动驾驶领域的专用视觉-语言-动作&#xff08;VLA&#xff09;模型&#xff0c;其100亿参数的规模带来了显著的性能提升&#xff0c;同时也对计算资源提出了…...

OPCServer DA版本:二次开发源代码及测试软件

OPCServer DA OPC服务端opcserver发包&#xff09;好用&#xff0c;几百个应用现场 二次开发源代码&#xff0c;C#开发&#xff0c;可二次开发。 已应用到多个行业的几百个应用现场&#xff0c;长时间运行稳定&#xff0c;可靠。 本项目中提供测试OPCServer的软件开发源码&am…...

Cesium与Vue.js融合构建:智慧管网三维可视化平台的架构演进与实践

1. 从零开始的智慧管网三维可视化平台架构设计 第一次接触智慧管网项目时&#xff0c;我被地下管线数据的复杂性震惊了。传统二维GIS系统就像用平面地图导航迷宫&#xff0c;而我们需要的是能透视地下五米的"X光眼"。这就是为什么选择Cesium作为核心引擎——它不仅能…...

FLUX.1-dev像素模型实战教程:自定义LoRA训练数据集构建指南

FLUX.1-dev像素模型实战教程&#xff1a;自定义LoRA训练数据集构建指南 1. 像素艺术生成新纪元 像素幻梦(Pixel Dream Workshop)是基于FLUX.1-dev扩散模型构建的下一代像素艺术生成工具。与传统AI绘图工具不同&#xff0c;它专为像素艺术创作优化&#xff0c;采用明亮的16-bi…...

openclaw平替之nanobot源码解析(七):Gateway与多渠道集成汹

背景 StreamJsonRpc 是微软官方维护的用于 .NET 和 TypeScript 的 JSON-RPC 通信库&#xff0c;以其强大的类型安全、自动代理生成和成熟的异常处理机制著称。在 HagiCode 项目中&#xff0c;为了通过 ACP (Agent Communication Protocol) 与外部 AI 工具&#xff08;如 iflow …...

Qwen3-ASR-1.7B开源大模型教程:PyTorch 2.5.0 + CUDA 12.4环境配置

Qwen3-ASR-1.7B开源大模型教程&#xff1a;PyTorch 2.5.0 CUDA 12.4环境配置 1. 引言&#xff1a;为什么选择Qwen3-ASR-1.7B&#xff1f; 如果你正在寻找一个开箱即用、功能强大的语音识别解决方案&#xff0c;Qwen3-ASR-1.7B绝对值得你花时间了解。这个由阿里通义千问团队推…...

各品牌电脑原厂OEM系统下载大全-纯净系统重装与恢复首选【宇程系统站】

在日常电脑使用过程中&#xff0c;系统卡顿、蓝屏、病毒感染等问题时有发生&#xff0c;很多用户都会选择重装系统来解决。但对于品牌电脑用户来说&#xff0c;普通系统镜像往往无法完整还原原厂环境&#xff0c;例如驱动缺失、功能不完整、无法自动激活等问题频繁出现。 因此&…...

APA第7版参考文献格式:3分钟解决Word引用难题

APA第7版参考文献格式&#xff1a;3分钟解决Word引用难题 【免费下载链接】APA-7th-Edition Microsoft Word XSD for generating APA 7th edition references 项目地址: https://gitcode.com/gh_mirrors/ap/APA-7th-Edition 还在为学术论文的参考文献格式而烦恼吗&#…...