【自学Flutter】25 InheritedWidget数据共享的使用

Widget build(BuildContext context) {

return MaterialApp(

home: Scaffold(

appBar: AppBar(title: Text(“数据共享InheritedWidget”),),

body: Center(

child: ShareDataInheritedWidget(

data: count,

child: Column(

mainAxisAlignment: MainAxisAlignment.center,

children: [

Padding(

padding: const EdgeInsets.all(20.0),

child: ShareDataTextWidget(),

),

Padding(

padding: const EdgeInsets.all(20.0),

child: ShareDataRedTextWidget(),

),

RaisedButton(

child: Text(“增加”),

onPressed: () => setState(() => ++count),

)

],

),

),

)

)

);

}

}

class ShareDataInheritedWidget extends InheritedWidget {

final int data;

ShareDataInheritedWidget({

@required this.data,

Widget child

}) :super(child: child);

static ShareDataInheritedWidget of(BuildContext context) {

return context.inheritFromWidgetOfExactType(ShareDataInheritedWidget);

}

@override

bool updateShouldNotify(ShareDataInheritedWidget old) {

return old.data != data;

}

}

class ShareDataTextWidget extends StatefulWidget {

@override

_ShareDataTextWidgetState createState() => new _ShareDataTextWidgetState();

}

class _ShareDataTextWidgetState extends State {

@override

Widget build(BuildContext context) {

return Text(ShareDataInheritedWidget.of(context).data.toString());

}

@override

void didChangeDependencies() {

super.didChangeDependencies();

print(“didChangeDependencies() 被调用”);

}

}

class ShareDataRedTextWidget extends StatefulWidget {

@override

_ShareDataRedTextWidgetState createState() => new _ShareDataRedTextWidgetState();

}

class _ShareDataRedTextWidgetState extends State {

@override

Widget build(BuildContext context) {

return Text(ShareDataInheritedWidget.of(context).data.toString(),style: TextStyle(color: Colors.red),);

}

@override

void didChangeDependencies() {

super.didChangeDependencies();

print(“didChangeDependencies() 被调用”);

}

}

2.解释源代码

import ‘package:flutter/material.dart’;

void main () => runApp(MyApp());

class MyApp extends StatefulWidget {

@override

_MyAppState createState() => _MyAppState();

}

class _MyAppState extends State {

//保存累加数

int count = 0;

@override

Widget build(BuildContext context) {

return MaterialApp(

home: Scaffold(

appBar: AppBar(title: Text(“数据共享InheritedWidget”),),

body: Center(

//创建ShareDataInheritedWidget,并继承InheritedWidget,当父

child: ShareDataInheritedWidget(

//当共享数据

data: count,

//当子

child: Column(

mainAxisAlignment: MainAxisAlignment.center,

children: [

Padding(

padding: const EdgeInsets.all(20.0),

//子widget中依赖ShareDataInheritedWidget

child: ShareDataTextWidget(),

),

Padding(

padding: const EdgeInsets.all(20.0),

//子widget中依赖ShareDataInheritedWidget

child: ShareDataRedTextWidget(),

),

RaisedButton(

child: Text(“增加”),

//每点击一次,将count自增,然后重新build,ShareDataTextWidget的data将被更新

onPressed: () => setState(() => ++count),

)

],

),

),

)

)

);

}

}

class ShareDataInheritedWidget extends InheritedWidget {

//需要在子树中共享的数据

final int data;

ShareDataInheritedWidget({

@required this.data,

Widget child

}) :super(child: child);

//定义方法,让子树中的widget获取共享数据

static ShareDataInheritedWidget of(BuildContext context) {

return context.inheritFromWidgetOfExactType(ShareDataInheritedWidget);

}

最后说一下我的学习路线

其实很简单就下面这张图,含概了Android所有需要学的知识点,一共8大板块:

  1. 架构师筑基必备技能
  2. Android框架体系架构(高级UI+FrameWork源码)
  3. 360°Androidapp全方位性能调优
  4. 设计思想解读开源框架
  5. NDK模块开发
  6. 移动架构师专题项目实战环节
  7. 移动架构师不可不学习微信小程序
  8. 混合开发的flutter

Android学习的资料

我呢,把上面八大板块的分支都系统的做了一份学习系统的资料和视频,大概就下面这些,我就不全部写出来了,不然太长了影响大家的阅读。

330页PDF Android学习核心笔记(内含上面8大板块)

Android学习的系统对应视频

总结

我希望通过我自己的学习方法来帮助大家去提升技术:

  • 1、多看书、看源码和做项目,平时多种总结

  • 2、不能停留在一些基本api的使用上,应该往更深层次的方向去研究,比如activity、view的内部运行机制,比如Android内存优化,比如aidl,比如JNI等,并不仅仅停留在会用,而要通过阅读源码,理解其实现原理

  • 3、同时对架构是有一定要求的,架构是抽象的,但是设计模式是具体的,所以一定要加强下设计模式的学习

  • 4、android的方向也很多,高级UI,移动架构师,数据结构与算法和音视频FFMpeg解码,如果你对其中一项比较感兴趣,就大胆的进阶吧!

希望大家多多点赞,转发,评论加关注,你们的支持就是我继续下去的动力!加油!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!
次的方向去研究,比如activity、view的内部运行机制,比如Android内存优化,比如aidl,比如JNI等,并不仅仅停留在会用,而要通过阅读源码,理解其实现原理

  • 3、同时对架构是有一定要求的,架构是抽象的,但是设计模式是具体的,所以一定要加强下设计模式的学习

  • 4、android的方向也很多,高级UI,移动架构师,数据结构与算法和音视频FFMpeg解码,如果你对其中一项比较感兴趣,就大胆的进阶吧!

希望大家多多点赞,转发,评论加关注,你们的支持就是我继续下去的动力!加油!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》点击传送门,即可获取!

  • 19
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值