首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何保持我的bottomNavigationBar Cubit BLoc的状态不稳定?

为了保持bottomNavigationBar Cubit BLoc的状态不稳定,可以采取以下方法:

  1. 使用Cubit和BLoC模式:Cubit和BLoC是Flutter中常用的状态管理模式,可以帮助我们管理应用程序的状态。通过使用Cubit和BLoC,可以将bottomNavigationBar的状态与其他部分的状态分离,从而实现状态的不稳定性。
  2. 使用Stream和StreamBuilder:使用Stream和StreamBuilder可以实现数据的实时更新和响应。可以将bottomNavigationBar的状态作为一个Stream,在需要更新状态的地方使用StreamBuilder来监听状态的变化,并根据状态的变化来更新UI。
  3. 使用Provider:Provider是Flutter中一个常用的状态管理库,可以帮助我们在应用程序中共享和管理状态。可以将bottomNavigationBar的状态作为一个Provider,在需要使用状态的地方使用Provider来获取状态,并根据状态的变化来更新UI。
  4. 使用SharedPreferences:SharedPreferences是Flutter中一个用于持久化存储的库,可以帮助我们将数据保存到本地。可以将bottomNavigationBar的状态保存到SharedPreferences中,在需要使用状态的地方从SharedPreferences中获取状态,并根据状态的变化来更新UI。
  5. 使用数据库:如果bottomNavigationBar的状态需要在不同的页面之间进行共享和同步,可以考虑使用数据库来存储和管理状态。可以将bottomNavigationBar的状态保存到数据库中,在需要使用状态的地方从数据库中获取状态,并根据状态的变化来更新UI。

总结起来,保持bottomNavigationBar Cubit BLoc的状态不稳定可以通过使用Cubit和BLoC模式、Stream和StreamBuilder、Provider、SharedPreferences或数据库等方法来实现。具体选择哪种方法取决于应用程序的需求和复杂度。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

flutter_bloc使用解析---骚年,你还在手搭bloc吗!

插件 在Android Studio设置Plugins里,搜索:Bloc [插件搜索] 安装重启下,就OK了 右击相应文件夹,选择“Bloc Class”,在main文件夹新建,填入名字:main...,state使用抽象状态继承实现方式,未免有点麻烦,这里进行一点小改动,state实现类别有很多,官网写demo也有不用抽象类,直接class,类似实体类方式开搞。...,还是需要用Bloc去写,需要将所有的事件行为管理起来,便于后期维护 OK,Bloc简化模块,Cubit模式就这样讲完了,对于自己业务写小项目,就经常用这个Cubit去写 全局Bloc 说明 什么是全局...,listener以响应bloc状态变化。...listenWhen获取先前bloc状态和当前bloc状态并返回一个布尔值。如果listenWhen返回true,listener将使用调用state。

5.4K41

【源码篇】Flutter Bloc背后思想,一篇纠结文章

view:页面 Cubit模式:该模式划分了三层结构 cubit:逻辑层 state:数据层 view:页面 作者在层次划分上还是很老道,state层是直接写死在框架内部,这层必须要单独分出来;感觉如果不是被大型项目的克苏鲁代码山坑过...,应该不会有这么深执念[img] 这个state层加觉得相当有必要,因为某个页面一旦维护状态很多,将状态变量和逻辑方法混在一起,后期维护会非常头痛。...模仿Bloc刷新机制,来手搓一个状态管理框架!用EasyC来命名吧!...[img] 为了证明分析源码是有作用且有效果,在末尾,都根据其状态管理框架刷新机制,手搓了一个全新状态管理框架 选择状态管理框架,应该是一件比较慎重事;事先可以先看看其原理,理解了他内部运转机制...Provider,Bloc,GetX这三个框架,都写了相应插件,如果你选择状态管理框架是这个三者中任意一个,相信这些插件,都能帮你完成一些重复工作量 [image-20210614225646560

2.4K41
  • 一种更优雅Flutter Dialog解决方案

    为了应对复杂业务场景,同时降低侵入性,在保持api稳定基础上,全面重构了SmartDialog底层 现在可以自信说:它现在是一个简洁,强大,侵入性极低Pub包 请使用Flutter 2.0及其以上小伙伴们移步...参数就很头疼;用fish_redux还好,effect层直接能拿到context,要是用bloc还得在view层把context传到bloc或者cubit里面。。。...看了其中源码,穿透背景解决方案,和预期想要效果大相径庭、一些dialog库自带toast显示,但是toast显示却又不能和dialog共存(toast属于特殊信息展示,理应能独立存在),导致需要多依赖一个...效果,请使用showToast方法定制就行了,炒鸡简单喔,懒得自己写,抄下ToastWidget,改下属性就行了哈 SmartDialog.showToast('test toast'); 使用Loading...flutter_bloc使用解析---骚年,你还在手搭bloc吗!

    3.6K41

    Confluence 6 如何保持空间整洁

    如果你有很多用户在同一个空间中编辑和创建内容,你空间将会很快变得混乱不堪。你可以使用下面的一些步骤来避免这个发生。...创建一系列指南 让你合作编辑用户知道创建页面的上级页面是什么,这样可以保证内容不会放错地方。 确定每一个页面,博客页面的和附件标签,这样能够保证内容更加整洁。...请参考 customize these Blueprints 页面中内容。每一个从蓝图中创建内容都会在边栏中有自己索引。...当这个按钮被单击后,宏编辑器将会打开,并允许你添加一个新页面和从基于给定模板中添加内容。...创建你自己页面模板 Create your own templates 能够让你将内容格式化成相同格式。

    92430

    掌握Flutter底部导航栏:畅游导航之旅

    6.2 使用Bloc进行状态管理 Bloc是另一个常用Flutter状态管理库,它基于流(Stream)和事件(Event)模式来管理应用程序状态,并提供了一种清晰、可维护方式来组织和处理复杂业务逻辑...通过创建一个NavigationBloc来处理底部导航栏状态,并在需要时向Bloc发送事件来更新状态,可以实现底部导航栏状态管理。...下面是一个示例,演示了如何使用Bloc进行底部导航栏状态管理: class NavigationBloc extends Bloc { NavigationBloc() : super...通过向Bloc发送事件,我们可以实现底部导航栏状态管理,并根据需要更新导航栏选中项状态。 7....此外,我们还探讨了如何利用状态管理库(如Provider和Bloc)来管理底部导航栏状态,以及如何实现一些高级功能,如添加徽章、动态更改导航栏项以及实现动画效果等。

    36210

    Flutter 桌面探索 | 自定义可拖拽导航栏

    前言 上一篇 《桌面导航 NavigationRail》 中介绍了官方桌面导航,但整体灵活性并不是太好,风格也不是很喜欢。看到飞书桌面端导航栏可以支持拖拽排序,感觉挺有意思。...这说明用户登录时会从服务器获取配置信息,作为导航栏状态数据决定显示。 本文我们将来探讨两个问题: 第一:如何将导航栏数据变得 可配置。 第二:如何实现 拖拽 更改导航栏位置。...需要考虑只有两件事: 如何 记录 和 维护 数据变化。 如何在数据变化后触发更新。 状态管理工具多种多样,但都不会脱离这两件本质工作,不同只是用法形式而已。...---- 这里用比较熟悉 flutter_bloc 来对激活菜单数据进行管理。现在引入 Cubit 后,对于小数据进行管理变得非常方便。...,可以单独抽离一个组件进行包裹 BlocProvider,这样其子树上下文中才可以访问到相关 Bloc

    2.3K20

    Flutter 对状态管理认知与思考

    逗笑了 [img] 关于上面的话,真不是吹牛皮,看了几个状态管理源码后,发现状态管理思想其实非常朴实,当然开源框架代码并没有那么简单,基本都做了大量抽象,方便功能扩展,这基本都会对阅读者产生极大困扰...,尤其是provider,看头皮发麻、、、 将几个典型状态管理思想提取出来后,用极简代码复现其运行机制,发现用都是观察模式思想,理解了以后,就并不觉得状态管理框架多么神秘了 绝没有任何轻视思想...如何将逻辑+状态层从界面里解耦出来?...,BlocBloc模式和Cubit模式,redux系列。。。...,也没感受到他给我带来好处,就只能把他无限弱化成一个刷新方法了 [img] 状态管理几种实现 这是看了一些状态管理源码 总结出几种状态管理刷新机制 任选一种,都可以搓出你自己状态管理框架

    1.1K41

    【Flutter&Flame 游戏 - 贰柒】pinball 源码分析 - 角色选择与玩法面板

    cubit 是业务逻辑处理,view 是视图呈现。...结合场景和个人喜好即可,并没有必要强制必须如何如何。没必要画个圈,或让别人给你画个圈,把自己行动范围定死,这点思考和选择能力还是要有的。 ---- 4....从这里可以看出 Bloc 处理可以根据状态来构建组件,也可以监听状态变化,进行逻辑处理。...---- 本文介绍了 pinball 游戏角色选择和玩法介绍 两个模块。从中可以看出 bloc状态数据共享,以及状态变化监听中价值。...下一篇,我们将进入最重要游戏主界面,那本文就到这里,明天见 ~ @张风捷特烈 2022.06.23 未允禁转 公众号: 编程之王 掘金主页 : 张风捷特烈 B站主页 : 张风捷特烈

    97640

    初学者 Flutter bloc

    flutter Bloc 是 Flutter 应用其中一个状态管理。我们可以通过它很容易处理应用中所有可能状态。...比如,如果 Bloc 发射一个成功状态,视图将根据返回游戏列表重新构建,但是如果返回状态是错误,视图会根据错误信息或者我们要展示其他内容来重新构建。...该 API 我们选择是 RAWG。为了使用它,我们需要创建一个 API Key。 本文我们不会介绍存储库和服务部分,但是如果你感兴趣,可以参考文本代码。 下面是完成应用效果。...当存储库返回有效数据,bloc 将返回放射成功信息,比如状态或者一份列表副本或者分类名字,相反,如果结果无效,bloc 需要返回错误状态。...bloc, Change change) { super.onChange(bloc, change); if (bloc is Cubit) print(change); }

    15610

    实现Flutter应用中全局导航栏效果

    状态管理器在实现全局导航栏效果中起到了至关重要作用,因为它可以确保不同页面之间导航栏状态保持一致。 什么是状态管理器?...GetX优点是简单易用、性能高效,适用于快速开发和小型项目。 BlocBloc是一种基于流状态管理器,它通过Stream来管理应用状态,并提供了强大事件处理和状态转换机制。...Bloc适用于大型应用和复杂业务逻辑。 如何使用状态管理器实现全局导航栏效果 要实现全局导航栏效果,可以使用任何一种状态管理器来管理导航栏状态,并在需要时更新导航栏内容和状态。...通常情况下,可以将导航栏状态提升到全局范围,然后在每个页面中访问和修改该状态。这样一来,无论用户在应用哪个页面,导航栏内容和状态保持一致,从而实现了全局导航栏效果。...然后,我们展示了如何根据需求选择合适方法,并提供了一个实际案例研究来演示如何使用Riverpod状态管理器实现全局导航栏效果。

    14411

    Flutter学习笔记:BottomNavigationBar实现多个Navigation

    multiple-navigators-BottomNavigationBar-animation.gif 如何实现此功能?...1_k5yMOPCem_z5JZVpa6RJCQ.gif 我们真正想要是将详细页面推到主页面上,但要将BottomNavigationBar保持在底部。...如果我们编译并运行应用程序,现在一切都按照预期方式工作。 我们可以独立地推送/弹出每个导航器,并且后台导航员保持他们状态。?...他想法是使用Stack with Offstage来保持导航器状态。...使用Offstage小部件可确保我们所有导航器保留其状态,因为它们保留在控件树中。 这可能会带来一些性能损失,因此如果您选择使用它,建议您分析您应用。 可以在此处找到本文完整源代码

    4.3K20

    Flutter实现页面切换后保持原页面状态3种方法

    它拥有一个固定底部导航以及首页顶部导航,可以看到不管是点击底部导航切换页面还是在首页左右侧滑切换页面,之前页面状态都是始终维持,下面就具体介绍下如何在flutter中实现类似喜马拉雅导航效果...,所有子页状态都被实例化了( 这里细节并不是因为直接把子页实例化放在bodyList里…<),如果在子页StateinitState中打印日志,可以在终端看到一次性输出了所有子页日志。...下面就介绍另一种通过继承AutomaticKeepAliveClientMixin方式来更好实现保持状态。...可以看到,现在添加了首页顶部导航,且默认支持左右侧滑,接下来再进一步完善状态保持 第四步:实现首页顶部导航切换时保持原页面状态 ③ 使用AutomaticKeepAliveClientMixin...所以,使用TabBarView+AutomaticKeepAliveClientMixin这种方式既实现了页面状态保持,又具有类似惰性求值功能,对于未使用页面状态不会进行实例化,减小了应用初始化时开销

    2.8K30

    Flutter 移动端架构实践:Widget-Async-Bloc-Service

    团队向我们展示了如何使用Provider包和ChangeNotifier,用于在组件之间传递状态更改。...状态管理和app架构看法 过去一年中,构建了若干大大小小Flutter app,期间遇到并解决了许多问题,这让明白了状态管理没有银弹。...在BLoC模式下,控件能够: 将事件分发给接收器; 通过流通知状态更新。 根据最初定义,我们只能通过 接收器 和 流 与BLoC进行通信。 虽然喜欢这个定义,但我发现它在许多场景下限制性太强。...[image] 将在稍后一些文章中更详细地讨论如何使用Provider。 目前为止,强烈推荐Google IO大会上这个演讲: https://www.youtube.com/watch?...无论如何发现BLoCs在使用Firestore构建app时效果非常明显,其中数据通过流从后端流入app。 在这种情况下,通常将流进行组合或使用RxDart对其执行转换,BLoC很擅长这个。

    16.1K20

    Flutter 状态管理方案:setState、BLoC、ValueNotifier、Provider

    此示例 app 展示了如何使用各种状态管理方案处理加载状态。 主要导航 登录页面的主要导航是通过一个小部件实现,该小部件使用 Drawer 菜单在不同选项中进行选择。...BLoC 加载状态可以由 BLoC 中,stream 值表示。...作为 BloC 替代方案,我们可以使用 BehaviorSubject 来跟踪加载状态,并根据需要进行更新。 我会通过 GitHub 项目 来展示具体如何实现。...在构建自己应用程序时,你可以根据具体情况来评估哪个方案更合适 小彩蛋:实现 Drawer 菜单 跟踪当前选择选项也是一个状态管理问题: 首先在自定义 Drawer 菜单中使用本地状态变量和 setState...源代码 可以在这里找到本教程中示例代码: State Management Comparison: [ setState ❖ BLoC ❖ ValueNotifier ❖ Provider ] 所有这些状态管理方案都在

    4.6K00

    【Flutter 状态管理】第一论: 对状态管理看法与理解

    但对于 状态 这种含义比较笼统词汇,那就仁者见仁,智者见智 了。查了一下,对于状态而言有如下解释: 状态是人或事物表现出来形态。...,以及如何将 重置 操作点击时,影响 page1 数字状态呢?...通过 onReset 回调函数来监听重置按钮触发,以此来重置 page1 数字状态,让 page1 数字可以与 page2 一致。这就是让两个界面的同一状态保持一致。...最后总结一下观点:状态就是界面构建需要依赖信息;而管理,就是通过分工,让这些状态信息可以更容易维护、更便于共享、更好同步变化 及 更'高效'地运转。...再回到那个最初问题,是所有的状态都需要管理吗?如何区分哪些状态需要管理?

    1.5K20
    领券