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

深圳整站全网推广销售方案怎么做

深圳整站全网推广,销售方案怎么做,为什么高德地图没有外国位置信息,威海外贸网站建设多少钱文章目录 概念介绍使用方法示例代码 我们在上一章回中介绍了"如何实现文件存储"相关的内容,本章回中将介绍 如何实现组件之间共享数据。闲话休提,让我们一起Talk Flutter吧。 概念介绍 数据共享是程序中常用的功能,本章回介绍如何…

文章目录

  • 概念介绍
  • 使用方法
  • 示例代码

我们在上一章回中介绍了"如何实现文件存储"相关的内容,本章回中将介绍 如何实现组件之间共享数据。闲话休提,让我们一起Talk Flutter吧。

概念介绍

数据共享是程序中常用的功能,本章回介绍如何在组件之间共享数据,不过这里提到的组件不是任意组件,主要指父组件与子组件,Flutter提供了InheritedWidget组件来实现共享数据的功能,本章回中将详细介绍如何使用该组件实现共享数据的功能。

使用方法

  1. 创建一个父类,类中至少包含两个属性:共享数据和子组件(child);
  2. 父类继承自InheritedWidget类,实现父类的中方法;
  3. 创建一个子类,子类中使用父类中共享的数据;
  4. 创建子类对象并且将它赋值给父类对象的子组件属性(childe);
  5. 更新父类中的共享数据,子组件中的共享数据会自动更新;

示例代码

///定义父组件,父组件包含一个共享数据data
class FatherWidget extends InheritedWidget {String data;FatherWidget({Key? key, this.data = "default data of Father", required Widget child}): super(key: key, child: child);///定义获取父组件的方法,方便子组件获取父组件中的数据static FatherWidget? of(BuildContext context) {///下面的方式可以通知子组件更新// return context.dependOnInheritedWidgetOfExactType<FatherWidget>();///下面的方式无法通知子组件更新return context.getElementForInheritedWidgetOfExactType<FatherWidget>()?.widget as FatherWidget;}///返回true时通知更新子组件中的data,也就是调用子组件的didChangeDependencies()方法bool updateShouldNotify(FatherWidget oldWidget) {return oldWidget.data != data;}
}///在子组件中使用父组件中的共享数据
class SonWidget extends StatefulWidget {const SonWidget({Key? key}) : super(key: key);State<SonWidget> createState() => _SonWidgetState();
}class _SonWidgetState extends State<SonWidget> {Widget build(BuildContext context) {String? data = FatherWidget.of(context)?.data;return Text("son data: $data",style: const TextStyle(color: Colors.white, fontSize: 24),);}void initState() {debugPrint("SonWidget: initState");}///父组件中的数据更新时会回调此方法void didChangeDependencies() {debugPrint("SonWidget: didChangeDependencies");}void dispose() {debugPrint("SonWidget: dispose");}void activate() {debugPrint("SonWidget: activate");}void deactivate() {debugPrint("SonWidget: deactivate");}void didUpdateWidget(SonWidget oldWidget) {debugPrint("SonWidget: didUpdateWidget");}
}children: [Container(width: 300,height: 100,alignment: Alignment.center,color: Colors.blue,child: FatherWidget(///父组件和子组件形成组件树data: _tempData,child: const SonWidget(),),),SizedBox(width: 200,height: 100,child: ElevatedButton(onPressed: () {setState(() {///更新父组件中的数据,子组件中数据会自动更新_tempData = "new data";});},child: const Text('Change data'),),),
],

代码中的FatherWidget是InheritedWidget的子类,重点关注一下of()方法的实现,通过该方法可以获取到FatherWidget的实例。该类中还有一个方法叫updateShouldNotify(),它决定是否更新子组件。

SonWidget本质上是Text组件的封装,它通过child属性与FatherWidget关联起来。代码中还提供了一个按钮,点击按钮时就会更新父组件中的数据,同时子组件中的数据也会被更新。我在这里就不演示程序的运行结果了,建议大家自己动手去实践。

看官们,关于"如何实现组件之间共享数据"相关的内容就介绍到这里,欢迎大家在评论区交流与讨论!

http://www.yayakq.cn/news/692100/

相关文章:

  • 网站制作中文版山东网站建设公司推荐
  • 双流区的规划建设局网站个人网站可以做咨询吗
  • 北京网站设计制作教程wordpress ajax 分页插件
  • 建设网站企业哪家好龙岗做网站哪里找
  • 网站上的图片做多大网站建设听取需求
  • 购买保险的网站seo关键词的优化技巧
  • 网站制作合同网站开发脚本语言和数据库
  • 网站建设与网页设计pptwordpress自动易语言
  • 河南浪博网站建设做网站后台的叫什么
  • 西安手机网站案例二手房地产中介网站建设
  • 小韩网站源码修改WordPress网站
  • 大连模板网站制作价格wordpress手机上打不开
  • 5118站长网站预装wordpress然后
  • 网站建设公司的排名怎么免费做文学网站
  • 三一国际网站设计eclipse tomcat 网站开发
  • 火炬开发区网站建设广州哪家公司做网站
  • 网站建设平台协议书模板下载做电影网站需多大的空间
  • 西安广告设计制作公司如何进行营销型企业网站的优化
  • 本地做那种网站好一些宁夏网站建设电话
  • 源码资源下载站6免费建站的网站
  • 成都 网站开发中天建设集团有限公司是国企吗
  • 深圳房地产信息网官方网站资讯网站优化排名
  • 做网站的等级保护要多少钱济南建筑工程网
  • 做网站前途如何wordpress客户端linux
  • 西安工程网站建设公司简介模板表格
  • 网站基础建设强化属地管理责任免费流量平台哪个最好
  • 网站开发的前端技术有哪些ps设计师网站有哪些
  • h5响应式网站开发wordpress使用
  • 将网站加入小程序wordpress 使用手册
  • ps网站logo制作教程wordpress 调用中等图片