flutter - flutter_bloc 子小部件关闭父小部件的块
问题描述
我正在使用 flutter_bloc 包。
我有一个带有标签栏的页面。该页面创建一个块并将其提供给用作选项卡内容的小部件。
class _MyScreenState extends State<MyScreen> {
MyBloc _myBloc;
...
Widget _buildTabBar() {
...
var children = [
_buildFirstTab()
_buildSecondTab(),
];
return WillPopScope(
onWillPop: _onWillPop,
child: DefaultTabController(
length: children.length,
child: Scaffold(
appBar: PreferredSize(
preferredSize: Size.fromHeight(75.0),
child: AppBar(
bottom: TabBar(isScrollable: true, tabs: tabs),
)),
body: TabBarView(
children: children,
),
),
),
);
}
..
}
Widget _buildSecondTab() {
if (_myBloc == null) {
_myBloc = MyBloc(<..initialdata..>);
}
_myBloc.add(LoadServerDataEvent());
return BlocProvider<MyBloc>(create: (_) => _myBloc, child: SecondTab());
}
第二个选项卡上的小部件从 BlocProvider 获取块并使用它。
class _SecondTabState extends State<SecondTab> {
MyBloc _myBloc;
@override
void initState() {
_myBloc = BlocProvider.of<MyBloc>(context);
super.initState();
}
我的问题是,当我在选项卡之间切换时,该块会自动关闭。
这有点奇怪,因为该块仍在页面上使用。
解决方案
好吧,你做错了几件事:
- 如果您希望您
bloc
在第一个和第二个选项卡中都可以访问,您应该用它包裹整个选项卡栏, - 很奇怪,你保留一个 bloc 的实例
_MyScreenState
并用惰性初始化单音做一些魔法if (_myBloc == null) _myBloc = MyBloc()
, - 大多数情况下
_myBloc.add(LoadServerDataEvent());
应该initState
在_SecondTabState
. bloc
从 UI 获取初始数据是非常不寻常的。如果你想构建你的架构,blocs
这个初始数据应该来自另一个bloc
。
但是,如果您想为第二个选项卡提供现有bloc
的并防止它被关闭,您应该使用:
BlocProvider.value(
value: _myBloc,
child: SecondTab(),
);
反而:
BlocProvider<MyBloc>(create: (_) => _myBloc, child: SecondTab());
推荐阅读
- typescript - 如何处理在Angular 6中返回带有resolve和reject的Promise的函数的测试用例
- c++ - 我的 unordered_set 元素在范围内更改而不修改它们
- azure - Azure CosmosDB:存储过程根据查询删除文档
- here-api - 这里地图使用的TTS引擎是什么
- docker - Dockerizing 一个面向包的设计 go modules 应用程序
- unity3d - Android 上的 Unity GPS 位置不经常更新
- python - Python 导入失败并带有崇高的文本,但程序通过控制台运行
- scala - 在另一个生成器中使用 ScalaCheck 生成器
- php - 使用 PHP 检测纯文本中的表情符号
- javascript - 为什么我不能让外部链接成为nofollow?