Flutter 功能型组件:跨组件状态共享(Provider)

Posted parzulpan

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Flutter 功能型组件:跨组件状态共享(Provider)相关的知识,希望对你有一定的参考价值。

前言

??在Flutter开发中,状态管理是一个永恒的话题。
??一般的原则是:如果状态是组件私有的,则应该由组件自己管理;如果状态要跨组件共享,则该状态应该由各个组件共同的父元素来管理。
??对于组件私有的状态管理很好理解,但对于跨组件共享的状态,管理的方式就比较多了,如使用全局事件总线EventBus,它是一个观察者模式的实现,通过它就可以实现跨组件状态同步:状态持有方(发布者)负责更新、发布状态,状态使用方(观察者)监听状态改变事件来执行一些操作。
??但是观察者模式来实现跨组件状态共享有一些明显的缺点:

  1. 必须显示定义各种事件,不好管理;
  2. 订阅者必须显式注册状态改变回调,也必须在组件销毁时手动去解绑回调以避免内存泄漏;

??是否还有更好的跨组件状态管理方式了?
??我们知道,InheritedWidget能绑定与它依赖的子孙组件的依赖关系,并且当InheritedWidget数据发生变化时,可以自动更新依赖的子孙组件。基于此,可以将需要跨组件共享的状态保存在InheritedWidget中,然后在子组件中引用InheritedWidget即可。Flutter社区的Provider包就是基于这个思想实现的。

Provider

代码示例

代码优化

总结

以上是关于Flutter 功能型组件:跨组件状态共享(Provider)的主要内容,如果未能解决你的问题,请参考以下文章

Flutter之跨组件共享状态Provider原理剖析

Flutter跨组件共享状态的利器Provider简析

Flutter跨组件共享状态的利器Provider框架简析

Flutter之跨组件状态共享Provider剖析

Flutter之跨组件状态共享Provider剖析

Flutter原理深入理解跨组件共享Provider