推广

Flutter分享 : 状态管理

iseeyu2年前 (2024-02-21)推广124

UI=f(State)

Flux、Redux、Fish_Redux

对于如何理解“状态管理”这个概念我还是想以追本溯源的方式来解释给大家听,首先,当前我们使用Flutter开发的项目用到的状态管理框架是阿里巴巴咸鱼团队开源的Fish_Redux, 而Fish_Redux的基本思想又是来源于React技术栈下的Redux,从Redux再往前推就是最初与React一同登场的Flux。

yNjidg.png

Flux : 缘起

在没有Flux和React之前,Facebook的工程师一直被一个小bug困扰

Facebook消息提示

一般社交类产品除了主屏上的动态列表,通常还会在明显的位置摆放一个查看消息的入口,这个入口上会有小红点表示当前有多少条未读消息。

yNjFoQ.png

当时有些用户发现在使用Facebook的过程中消息入口上有小红点,但是点击进消息列表却没有未读消息的情况。用户看到红点进入消息页没有未读消息,小红点消失,过一会儿小红点再次出现,进入消息页依旧没有未读消息。就这样循环往复,开发团队也是在修复bug再次出现这个bug中循环往复。

不可预测的MVC

我们先来看看当时当时Facebook项目的架构,对于小型项目来说的MVC模型,看起来似乎还挺可靠的

yUSt4e.jpg

但是随着业务量的增大,MVC的问题越来越明显,依赖关系和各种层级的更新经常在大型MVC应用程序中发生,从而导致数据流错综复杂和不可预期的结果,前面的bug也是在这样的项目结构下,出现循环引用而导致的。

yNjAij.png

解决方案

为此,facebook的工程师打算将项目架构推倒重来,目标是为了更快的开发效率和更高的代码质量,为了做到这两点需要的是可预测的代码,也就因此最后分别开发出了响应式UI框架React来达到UI的可预测,状态管理框架Flux达到数据的可预测。

yNjEJs.png

Flux

Action是由ActionCreators提供给Dispactcher,通常是由用户与视图的交互产生的
Dispactcher将会根据Action的类型来通知Store触发页面初始化时在Store中注册的回调
Store响应Dispactcher的请求对其内所维护的状态进行相关操作,操作完成后将会通过Event Handler告诉View有数据发生改变
View监听到数据改变并从Event Handler中获取对应的数据以此来刷新UI

yNjVWn.png

Redux : 优化Flux

在Flux发布之后一段时间里Dan Abramov看到了可以优化Flux的可能,于是就基于Flux创造出了Redux

Redux在Flux的基础上做出了一些改进,在Flux中Store包含了状态改变的逻辑和当前应用的状态,而在Redux中将Store的两个部分拆分为处理状态改变逻辑的Reducer和状态State,在Flux中没有提供给开发则监听单向数据流的拓展,而Redux将Dispactcher改名为Dispatch,并在其中提供了用于监听数据流拓展接口。Redux具体流程和Flux类似,其中需要注意的是Reducer响应Dispatch时不仅会收到Action的信息还会有当前状态的拷贝,Reducer对拷贝的状态操作完成后,传递给State并由此更新。

yNjZzq.png

Redux特性

通过对Flux的优化,Redux得到了更便捷的热重载,可以回退应用状态的时间旅行,以及可以监控单向数据流的拓展接口

热重载:在开发应用程序时,通常是一个接一个的小改动。您看到较小更改的效果的速度越快,开发就会越快。热重载的优点在于,可以实时的将修改的逻辑代码更新到应用中,而应用程序的状态却不会重置。虽然React配合Flux也可以热重载,但是因为Store中包含了应用状态和逻辑代码,如果对Store的代码热重载将会丢失当前的状态。在Redux中将Store拆分后,即可对操作状态的逻辑代码进行热重载了。

时间旅行:通过拷贝状态的方式,可以得到一连串的状态切片,每个切片又由对应的Action触发,有了这些切片,我们在调试程序的过程中,可以进行时间回溯,重新加载出现错误时的前一个状态。例如,在测试的过程中执行了某个操作导致出现异常,我可以回退到上一步,重新来一次。

可拓展接口:可以通过Dispatch监听所有经过它的Action,可以用来打印日志,用来埋点等等。

yNjuLT.png

Fish_Redux:适配Flutter

Fish Redux 基于Redux在Flutter端的状态管理框架。将Redux中的Reducer再区分出了一个Effect

因为Flutter编译的发布包是AOT,代码中不支持反射、Hook等操作,所以无法判断Reducer处理完成后的状态是否有更新,因此需要将不做状态更新的代码显式的移到Effect中去执行,这样也是为了不让UI刷新过于频繁,影响性能。

yNjnyV.png

扫描二维码推送至手机访问。

版权声明:本文由西安泽虎代运营发布,如需转载请注明出处。

转载请注明出处https://www.0291.com.cn/post/57254.html

相关文章

梳理总结百度、谷歌、360、神马、必应和搜狗搜索引擎收录提交入口网址。

梳理总结百度、谷歌、360、神马、必应和搜狗搜索引擎收录提交入口网址。

SEO网站管理员都知道,网站提交到搜索引擎可以更好地促进我们的品牌。当用户使用搜索引擎搜索关键词时,他们可以更好地显示我们的网站,增强曝光,增强流量,终带来变革。因此,把网站提交给主要的搜索引擎是我们网站推广的开始。下面的重蔚自留地SEO博客整理了百度、谷歌、360、神马、必应和搜狗搜索引擎的提交条...

薇娅的淘宝店叫什么,薇娅店铺销量高没评价(薇娅的店铺叫什么)

薇娅的淘宝店叫什么,薇娅店铺销量高没评价(薇娅的店铺叫什么)

店铺名称:薇娅viya店铺直达:https://weiyaviya.taobao.com​,她的店铺是一家ifashion店铺,已经是6年老店,店铺主要经营女装。...

小红书爆红背后,有可复制的内容运营策略。

小红书爆红背后,有可复制的内容运营策略。

活跃度暴增的小红书,到底是如何运营社区的呢? 半个月前,小红书宣布完成 3 亿美金的 D 轮融资,沉静已久的小红书又回到的媒体的聚光灯下。 小红书最初还是一个带有购物攻略性质的海淘化妆品平台,然而随着电商红利期过去,小红书也开始躲避“电商”一词,其联合创始人瞿芳曾经公开表示,小红书不是一...

丁香医生整合营销推广方案

丁香医生整合营销推广方案

查看完整方案或更多方案点击...

一文看懂视频号与抖音的运营逻辑

一文看懂视频号与抖音的运营逻辑

  最近在一个运营行业的交流群里,本来经常处于沉寂的群,在一个运营小白的不断发问中和工作吐槽中,群内氛围反而活跃了起来。通过这位职场运营小白的问题中,我发现了很多人对抖音和视频号两个平台的底层推荐逻辑还并不清楚。 像抖音中有很多知识类博主,会讲很多不同版本的抖音运营方法,有的...

小红书能抄抖音本地生活的作业吗?

小红书能抄抖音本地生活的作业吗?

最近有消息传出,小红书后续将加码本地生活业务,上线团购功能,最近不少商家就表示已经参与了小红书的团购内测。那么,小红书的这一动作会带来什么“水花”?抖音在本地生活业务的布局策略,小红书能借鉴吗?一起来看看作者的分析。 小红书正在探索美团、抖音以外,本地生活市场的第三种解决方案。...

现在,非常期待与您的又一次邂逅

我们努力让每一部企业宣传片和抖音短视频成为商业大片