如何解决可见性小部件打开/关闭可刷新整个页面
如果“可见性窗口小部件”不允许子窗口小部件显示,如何停止窗口小部件的刷新?
下面的示例显示Visibility
小部件,该小部件根据条件打开/关闭子小部件,但是在隐藏和显示此小部件的情况下,另一个小部件必须进行调整/重新渲染。
那么,所有人都想停止其他小部件的重新渲染吗?我该怎么办?
Row(
children: <Widget>[
MyWidget1(),MyWidget2(),Visibility(
visible: condition == true,child: MyWidget3(),),],);
解决方法
找到了解决方案!
Visibility
小部件的一些属性可以帮助我们解决此问题,
maintainState::在子窗口小部件隐藏时维护状态。
maintainAnimation :在子窗口小部件隐藏时维持其动画。
maintainSize::在隐藏子窗口小部件空间时对其进行维护。
使用所有这些属性,我们可以按原样保留MyWidget3(
)小部件,
Visibility(
visible: condition == true,maintainState: true,maintainAnimation: true,maintainSize: true,child: MyWidget3(),)
,
最常见,最简单的解决方案是使用
提供者-https://pub.dev/packages/provider
软件包来管理小部件状态,然后可以使用使用者小部件来重建需要更新的小部件。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。