如何解决状态生成器在使用交互式滚动查看器时不会在颤动中更新列表
我正在使用 InteractiveScrollViewer 并且列表没有在添加和更新功能上更新,所以我将 StatefulBuilder 用于 CardList。现在它在同一页面上工作正常,但是如果我推送另一个页面,即 endDrawer 并在我弹出页面时在那里更新项目,页面中不会显示任何效果。
StatefulBuilder(
builder:
(BuildContext context,StateSetter _setState) =>
我正在更新抽屉关闭时运行的某个函数中的项目列表。我无法在此函数中发送 _setstate,因为此函数是全局函数。
我可以对嵌套滚动视图使用哪些其他技术。
编辑:
bloc.getAllFoodItems(_id).then((value) {
if (!mounted) return;
setState(() {
_itemList = value;
if (menuItemsList != null && menuItemsList.length != 0)
for (int i = 0; i < menuItemsList.length; i++) {
if (menuItemsList[i].id != null) {
int ls = -1;
if (_itemList != null)
ls = _itemList
.indexWhere((item) => item.itemID == menuItemsList[i].id);
if (ls != -1) {
setState(() {
menuItemsList[i].quantity = _itemList[ls].quantity;
});
} else
setState(() {
menuItemsList[i].quantity = 0;
});
}
}
});
});
此代码在绘图关闭时运行。
解决方法
您的问题是状态管理。
当你说你是从另一个页面更新时,主要问题是你的 Drawer 可能没有全局保存状态,所以任何想要获取信息以构建 CardsList 的页面都将使用相同的信息。
现在主要的决策点是决定您要使用哪个状态管理系统。您可以拥有以下任何一种甚至更多:Provider、Bloc、InheritedWidget 等。 以下是 Flutter 官方文档中关于许多选项的列表: https://flutter.dev/docs/development/data-and-backend/state-mgmt/options
PS:对于简单的应用,我会推荐 MobX 或 GetX,因为它减少了样板。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。