flutter鸿蒙next 使用 InheritedWidget 实现跨 Widget 传递状态
在 Flutter 中,状态管理是开发过程中一个至关重要的部分。Flutter 提供了多种方式来实现组件间的状态传递,其中一种比较底层的方式是使用 InheritedWidget
。虽然 InheritedWidget
主要用于将数据传递给其子树中的小部件,但它也是许多更高级状态管理解决方案(如 Provider
)的基础。本文将详细介绍如何使用 InheritedWidget
来实现跨 Widget
的状态传递。
1. InheritedWidget
基础介绍
InheritedWidget
是 Flutter 框架提供的一个特殊 Widget,它允许数据在 Widget 树中向下传递。当一个 Widget 需要跨越多个子 Widget 传递数据时,可以将数据保存在 InheritedWidget
中,并让它作为一个数据的容器。所有依赖于这个 InheritedWidget
的子 Widget,都能方便地获取到这些数据。
InheritedWidget
的工作原理
InheritedWidget
主要依赖of
方法来从 Widget 树的不同位置读取数据。InheritedWidget
会在其child
发生变化时触发树重建。这意味着它不仅可以传递数据,还能在数据发生变化时自动更新界面。
2. 示例代码:实现一个简单的计数器
为了让大家更清楚地理解 InheritedWidget
的使用,我们通过实现一个简单的计数器来展示它是如何跨 Widget 传递状态的。
完整代码
import 'package:flutter/material.dart';// 1. 创建一个 InheritedWidget,用于传递状态
class CounterInheritedWidget extends InheritedWidget {final int counter;final Function() increment;CounterInheritedWidget({Key? key,required this.counter,required this.increment,required Widget child,}) : super(key: key, child: child);// 创建一个方法,方便其他组件获取到当前的 CounterInheritedWidget 实例static CounterInheritedWidget of(BuildContext context) {final result = context.dependOnInheritedWidgetOfExactType<CounterInheritedWidget>();assert(result != null, 'No CounterInheritedWidget found in context');return result!;}@overridebool updateShouldNotify(CounterInheritedWidget oldWidget) {// 当 counter 发生变化时,通知子 Widget 进行更新return counter != oldWidget.counter;}
}// 2. 创建一个使用 CounterInheritedWidget 的页面
class CounterPage extends StatelessWidget {@overrideWidget build(BuildContext context) {// 获取状态数据final counter = CounterInheritedWidget.of(context).counter;final increment = CounterInheritedWidget.of(context).increment;return Scaffold(appBar: AppBar(title: Text('InheritedWidget Counter')),body: Center(child: Column(mainAxisAlignment: MainAxisAlignment.center,children: <Widget>[Text('Counter Value: $counter', style: TextStyle(fontSize: 30)),SizedBox(height: 20),ElevatedButton(onPressed: increment,child: Text('Increment'),),],),),);}
}// 3. 创建一个 StatefulWidget 来管理数据并使用 CounterInheritedWidget
class CounterApp extends StatefulWidget {@override_CounterAppState createState() => _CounterAppState();
}class _CounterAppState extends State<CounterApp> {int _counter = 0;// 增加计数void _incrementCounter() {setState(() {_counter++;});}@overrideWidget build(BuildContext context) {return CounterInheritedWidget(counter: _counter,increment: _incrementCounter,child: CounterPage(),);}
}void main() {runApp(MaterialApp(home: CounterApp()));
}
代码解释
1. CounterInheritedWidget
类
CounterInheritedWidget
是继承自 InheritedWidget
的自定义类,它将计数器的值和 increment
方法封装在其中。这个 Widget 会被用来向下传递数据(在这里是计数器的值和一个函数)。
- 构造函数:接收
counter
(计数器的值)、increment
(增加计数的函数)和child
(需要显示的子组件)。 of
方法:是一个静态方法,用于从BuildContext
获取到最近的CounterInheritedWidget
实例。它会从当前上下文的InheritedWidget
树中向上查找,找到最近的CounterInheritedWidget
并返回。updateShouldNotify
方法:当CounterInheritedWidget
的counter
值变化时,返回true
,通知 Widget 树的依赖此 Widget 的所有子 Widget 重新构建。
2. CounterPage
页面
CounterPage
是显示计数器值的页面,它通过 CounterInheritedWidget.of(context)
来获取 counter
和 increment
。increment
是一个回调函数,用来更新计数器的值,counter
是计数器的当前值。
3. CounterApp
类
CounterApp
是一个 StatefulWidget
,负责管理计数器的状态。它的 build
方法返回一个 CounterInheritedWidget
,并将 _counter
和 _incrementCounter
传递给它。这个 Widget 作为根 Widget 包裹 CounterPage
,让计数器的值和方法能够通过 InheritedWidget
传递给页面中的所有子 Widget。
4. 启动应用
main
方法启动应用,设置 CounterApp
为根 Widget。CounterApp
会初始化计数器的状态并通过 CounterInheritedWidget
传递给 CounterPage
,使得子 Widget 可以访问和更新状态。
3. 如何工作?
CounterInheritedWidget
将counter
和increment
方法传递给其子树中的CounterPage
。CounterPage
通过CounterInheritedWidget.of(context)
方法获取CounterInheritedWidget
实例,从而访问counter
和increment
。- 当按下 "Increment" 按钮时,
_incrementCounter
被调用,导致setState
被触发,_counter
的值更新。由于CounterInheritedWidget
中的counter
值发生变化,它会通知所有依赖它的 Widget 重新构建。最终,CounterPage
重新渲染,显示更新后的计数器值。
4. 小结
使用 InheritedWidget
可以让我们方便地将数据传递到 Widget 树的深层。它的优势在于:
- 提供了一种高效、性能优化的状态传递方式。
- 可以在多层嵌套的 Widget 中传递数据,避免了通过
setState
或回调的层层传递。
虽然 InheritedWidget
功能强大,但它的使用较为底层,Flutter 也提供了 Provider
等更高级的状态管理工具,可以在更复杂的应用中提供更加灵活和简洁的状态管理方案。
相关文章:
flutter鸿蒙next 使用 InheritedWidget 实现跨 Widget 传递状态
在 Flutter 中,状态管理是开发过程中一个至关重要的部分。Flutter 提供了多种方式来实现组件间的状态传递,其中一种比较底层的方式是使用 InheritedWidget。虽然 InheritedWidget 主要用于将数据传递给其子树中的小部件,但它也是许多更高级状…...

计算机的错误计算(一百四十六)
摘要 探讨 MATLAB 中正切函数 tan(x)、余切函数 cot(x) 关于 附近数的计算精度问题。 例1. 已知 计算 直接贴图吧: 另外,16位的正确值分别为 -0.7837941516239115e10、-0.1275845192169577e-9、0.4782331334117711e7 与 0.2091030357653982e-…...

国标GB28181视频平台EasyCVR私有化视频平台工地防盗视频监控系统方案
一、方案背景 在当代建筑施工领域,安全监管和防盗监控是保障工程顺利进行和资产安全的关键措施。随着科技进步,传统的监控系统已不足以应对现代工地的安全挑战。因此,基于国标GB28181视频平台EasyCVR的工地防盗视频监控系统应运而生…...

CUDA系统学习之一软件堆栈架构
一、CPU与GPU体系架构 计算单元分布 CPU: 少量强大的ALU(算术逻辑单元),通常4-8个核心GPU: 大量小型ALU,成百上千个计算核心特点:GPU更适合并行计算,可以同时处理大量数据控制单元(Control) CPU: 较大的控制单元,复杂的…...
SpringBoot项目中替换指定版本的tomcat
需求:项目使用的SpringBoot框架,因低版本的tomcat的有安全漏洞,根据安全要求需要将项目的tomcat版本升级到9.0.89以上版本。 解决办法: 1、在pom.xml中排除SpringBoot的默认tomcat依赖; <dependency><groupId…...

【5.10】指针算法-快慢指针将有序链表转二叉搜索树
一、题目 给定一个单链表,其中的 元素按升序排序 ,将其转换为 高度平衡的二叉搜索树 。 本题中,一个高度平衡二叉树是指一个二叉树每个节点的左右两个子树的高度差的绝对值不超过 1。 示例: 给定的有序链表: [ -10 , -3 , 0 , …...

机器学习—前向传播的一般实现
可以写一个函数来实现一个密集的层,那是神经网络的单层,所以定义稠密函数,它将上一层的激活作为输入以及给定层神经元的参数w和b。看下边图片所展示的例子,把所有这些权重向量堆叠成一个矩阵,wnp.array([[1,-3,5][2,4,…...
极狐GitLab 签约足下科技,加速国产智驾操作系统的发展与普及
客户背景 足下科技是一家致力于成为智能汽车软件平台、产品与服务领导者的高科技企业,成立于 2022年 3 月,总部位于深圳市。足下科技自主研发的智能驾驶操作系统 Earth 和 Air 工具链,协助OEM和Tier1厂商降低算法和软件开发难度,…...

20241102在荣品PRO-RK3566开发板的预置Android13下适配宸芯的数传模块CX6603N
20241102在荣品PRO-RK3566开发板的预置Android13下适配宸芯的数传模块CX6603N 2024/11/2 18:04 在WIN10使用程序:ViewLink-4.0.7_0708-windows-x64.exe 在荣品PRO-RK3566开发板的预置Android13下使用:ViewLink-2023_12_21-release-0.2.6.apk adb install…...

力扣(leetcode)题目总结——哈希表篇
leetcode 经典题分类 链表数组字符串哈希表二分法双指针滑动窗口递归/回溯动态规划二叉树辅助栈 本系列专栏:点击进入 leetcode题目分类 关注走一波 前言:本系列文章初衷是为了按类别整理出力扣(leetcode)最经典题目,…...
AWS RDS Oracle hit ORA-39405
报错信息: ORA-39405: Oracle Data Pump does not support importing from a source database with TSTZ version 42 into a target database with TSTZ version 35. 分析过程: 这个报错是由于timezone_file的版本,源端比目标端高…...

Dinky中配置Flink集群
需要启动yarn-session 进程,在集群服务器 cd /pwd//flink/bin yarn-session -d 启动成功后可以在yarn的资源管理队列进行查看 启动成功后会给出:JobManager Web Interface 在dinky中进行配置: 集群配置 Hadoop 配置: H…...

通讯录(C 语言)
目录 一、通讯录设计思路1. 伪代码设计思路2. 代码设计思路 二、代码实现三、程序运行演示四、整体分析 一、通讯录设计思路 1. 伪代码设计思路 通讯录可以用来存储 100 个人的信息,每个人的信息包括:姓名、性别、年龄、电话、住址。 提供方法&#x…...
对比Java和TypeScript中的服务注册和查找机制
文章目录 一、Java中的服务注册和查找二、TypeScript中的服务注册和查找2.1 使用依赖注入(DI)框架2.2 injectable原理2.3 使用TypeScript的反射系统实现依赖注入 三、优缺点分析3.1 Java的ServiceLoader3.2 TypeScript的服务注册和查找 四、结论 在构建大…...
Flutter 主流常用第三方库、插件收集
一、Flutter 学习资料 FlutterFlutter官网Flutter中文网咸鱼技术掘金Flutter专栏 Flutter - Dart中(.)、(..)、(...)语法使用_flutter ...-CSDN博客 Flutter pubspec.yaml 配置文件_flutter yaml配置git-CSDN博客 Flutter 添加 example流程_建flutter 工程 怎么自动有example-C…...

【在Linux世界中追寻伟大的One Piece】多路转接select
目录 1 -> I/O多路转接之select 1.1 -> 初识select 1.2 -> select函数原型 1.3 -> 关于fd_set结构 1.4 -> 关于timeval结构 2 -> 理解select执行过程 2.1 -> Socket就绪条件 2.2 -> select特点 2.3 -> select缺点 3 -> select使用示例…...

补一下 二维 平面直角坐标系 到三维
上一篇帖子写到 二维的平面直角坐标系,是那样的,这次补充一下三维的。首先需要,安装一个包,如下: 然后,把参数输入,输入这个坐标系的参数,如下: 这样就可以输出如下的三…...
如何学习Python编程?
如何学习Python编程? 了解基础概念: 学习Python的基本语法,包括变量、数据类型、运算符等。了解控制结构,如条件语句(if语句)和循环(for和while循环)。 选择学习资源: 在…...

使用EasyExcel实现导出excel文件时生成多级下拉选
前言 公司有个需求本来只涉及到两个下拉选项,后面就想能不能实现多个下拉选,当然我这里说的多个下拉选是联动的,比如省、地市、区县这种。 实现步骤 1、添加EasyExcel的Maven依赖 <dependency><groupId>com.alibaba</group…...

微信小程序 高校教材征订系统
文章目录 项目介绍具体实现截图技术介绍mvc设计模式小程序框架以及目录结构介绍错误处理和异常处理java类核心代码部分展示详细视频演示源码获取 项目介绍 系统分为三个角色,分别是教材科、系教学秘书、教研室主任。系统主要完成功能是教材科要发布教材征订信息&am…...

网络编程(Modbus进阶)
思维导图 Modbus RTU(先学一点理论) 概念 Modbus RTU 是工业自动化领域 最广泛应用的串行通信协议,由 Modicon 公司(现施耐德电气)于 1979 年推出。它以 高效率、强健性、易实现的特点成为工业控制系统的通信标准。 包…...

MFC内存泄露
1、泄露代码示例 void X::SetApplicationBtn() {CMFCRibbonApplicationButton* pBtn GetApplicationButton();// 获取 Ribbon Bar 指针// 创建自定义按钮CCustomRibbonAppButton* pCustomButton new CCustomRibbonAppButton();pCustomButton->SetImage(IDB_BITMAP_Jdp26)…...

家政维修平台实战20:权限设计
目录 1 获取工人信息2 搭建工人入口3 权限判断总结 目前我们已经搭建好了基础的用户体系,主要是分成几个表,用户表我们是记录用户的基础信息,包括手机、昵称、头像。而工人和员工各有各的表。那么就有一个问题,不同的角色…...
数据链路层的主要功能是什么
数据链路层(OSI模型第2层)的核心功能是在相邻网络节点(如交换机、主机)间提供可靠的数据帧传输服务,主要职责包括: 🔑 核心功能详解: 帧封装与解封装 封装: 将网络层下发…...

分布式增量爬虫实现方案
之前我们在讨论的是分布式爬虫如何实现增量爬取。增量爬虫的目标是只爬取新产生或发生变化的页面,避免重复抓取,以节省资源和时间。 在分布式环境下,增量爬虫的实现需要考虑多个爬虫节点之间的协调和去重。 另一种思路:将增量判…...
C#中的CLR属性、依赖属性与附加属性
CLR属性的主要特征 封装性: 隐藏字段的实现细节 提供对字段的受控访问 访问控制: 可单独设置get/set访问器的可见性 可创建只读或只写属性 计算属性: 可以在getter中执行计算逻辑 不需要直接对应一个字段 验证逻辑: 可以…...

【p2p、分布式,区块链笔记 MESH】Bluetooth蓝牙通信 BLE Mesh协议的拓扑结构 定向转发机制
目录 节点的功能承载层(GATT/Adv)局限性: 拓扑关系定向转发机制定向转发意义 CG 节点的功能 节点的功能由节点支持的特性和功能决定。所有节点都能够发送和接收网格消息。节点还可以选择支持一个或多个附加功能,如 Configuration …...
深度剖析 DeepSeek 开源模型部署与应用:策略、权衡与未来走向
在人工智能技术呈指数级发展的当下,大模型已然成为推动各行业变革的核心驱动力。DeepSeek 开源模型以其卓越的性能和灵活的开源特性,吸引了众多企业与开发者的目光。如何高效且合理地部署与运用 DeepSeek 模型,成为释放其巨大潜力的关键所在&…...

ubuntu系统文件误删(/lib/x86_64-linux-gnu/libc.so.6)修复方案 [成功解决]
报错信息:libc.so.6: cannot open shared object file: No such file or directory: #ls, ln, sudo...命令都不能用 error while loading shared libraries: libc.so.6: cannot open shared object file: No such file or directory重启后报错信息&…...
LLaMA-Factory 微调 Qwen2-VL 进行人脸情感识别(二)
在上一篇文章中,我们详细介绍了如何使用LLaMA-Factory框架对Qwen2-VL大模型进行微调,以实现人脸情感识别的功能。本篇文章将聚焦于微调完成后,如何调用这个模型进行人脸情感识别的具体代码实现,包括详细的步骤和注释。 模型调用步骤 环境准备:确保安装了必要的Python库。…...