import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
class ShareDataWidget<T> extends InheritedWidget {
ShareDataWidget({Key? key, required this.child, required this.data})
: super(key: key, child: child);
final Widget child;
final T data;
@override
bool updateShouldNotify(ShareDataWidget<T> oldWidget) {
return true;
}
}
class ChangeNotifierProvider<T extends ChangeNotifier> extends StatefulWidget {
ChangeNotifierProvider({Key? key, required this.child, required this.creater})
: super(key: key);
final T Function(BuildContext context) creater;
final Widget child;
//添加一个listen参数,表示是否建立依赖关系
static T of<T>(BuildContext context, {bool listen = true}) {
final provider = listen
? context.dependOnInheritedWidgetOfExactType<ShareDataWidget<T>>()
: context
.getElementForInheritedWidgetOfExactType<ShareDataWidget<T>>()
?.widget as ShareDataWidget<T>;
return provider!.data;
}
// 需要使用_ChangeNotifierProviderState<T> 不然后会provider会是null
// @override
// State<ChangeNotifierProvider> createState() =>
// _ChangeNotifierProviderState<T>();
_ChangeNotifierProviderState<T> createState() =>
_ChangeNotifierProviderState<T>();
}
class _ChangeNotifierProviderState<T extends ChangeNotifier>
extends State<ChangeNotifierProvider> {
late T data;
@override
void initState() {
data = widget.creater(context) as T;
data.addListener(update);
super.initState();
}
@override
Widget build(BuildContext context) {
return ShareDataWidget(child: widget.child, data: data);
}
@override
void dispose() {
data.removeListener(update);
super.dispose();
}
update() {
setState(() {});
}
}
class Consumer<T> extends StatelessWidget {
const Consumer({Key? key, required this.builder}) : super(key: key);
final Widget Function(BuildContext context, T value) builder;
@override
Widget build(BuildContext context) {
return builder(context, ChangeNotifierProvider.of<T>(context));
}
}
class ThemeState extends ChangeNotifier {
late int settingThemeCoror;
ThemeState({required this.settingThemeCoror});
void changeTheme(int thmeColor) {
this.settingThemeCoror = thmeColor;
notifyListeners();
}
}
class InheritedWidgetTestRoute extends StatefulWidget {
@override
_InheritedWidgetTestRouteState createState() =>
_InheritedWidgetTestRouteState();
}
class _InheritedWidgetTestRouteState extends State<InheritedWidgetTestRoute> {
int count = 0;
@override
Widget build(BuildContext context) {
return ChangeNotifierProvider<ThemeState>(
creater: (context) => ThemeState(settingThemeCoror: 222),
child: Consumer<ThemeState>(builder: (context, value) {
return Column(
children: [
Container(
child: Text(value.settingThemeCoror.toString()),
),
CupertinoButton(
child: Text("新增"),
onPressed: () {
value.changeTheme(12345);
})
],
);
}),
);
}
}
InheritedWidget共享数据学习
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- InheritedWidget 是Flutter 中非常重要的一个功能性组件,他的主要作用是用来提供一种从上到下的...
- 1、背景介绍 在使用QT做项目开发过程中,经常会用到多线程,比如图像采集一个线程,图像处理一个线程、数据通讯一个线...
- 简介 业务开发中经常会碰到这样的情况,多个Widget需要同步同一份全局数据,比如点赞数、评论数、夜间模式等等。在...
- 推荐一个Java学习群523401738每天晚上在腾讯课堂都有一个Java技术学习课,会有老师分享干货,帮助大家分...