[英]Avoid rebuilding screen with Future builder
我正在使用FutureBuilder和Provider从我的服务器获取数据,这很好,因为它删除了很多样板,但缺点是 FutureBuilder 每次我更改屏幕时都会重建屏幕。
从性能的角度来看,这并不好,我更喜欢让用户在需要时使用拉动来刷新,并在需要时更改我的对象列表。
是否可以缓存未来的构建器或在InitState中使用它?
未来的建造者是否适合我的情况?
Future Builder (为了便于阅读,省略了部分代码):
FutureBuilder(
future: Provider.of<MyProvider>(context, listen: false).fetch();,
builder: (ctx, dataSnapshot) {
...
final Data =
Provider.of<MyProvider>(context, listen: false);
return Consumer<MyProvider>(
builder: (ctx, orderData, child) {
....
itemCount: data.length,
itemBuilder: (ctx, i) => MyItem()
},
);
}
}
},
),
RefreshIndicator
可能是您正在寻找的(文档解释了它是如何工作的比我更好的https://api.flutter.dev/flutter/material/RefreshIndicator-class.ZFC35FDC70D5FC69D235883A8E2C7 )
您可以让您的页面watch
您的Provider
(可能是ChangeNotifierProvider
,以便它可以notifyListeners
并触发重建),并让您的RefreshIndicator.onRefresh
调用您的刷新方法来更新包装在您的Provider
中的小部件中的值(并在您的异步 function 运行时的页面)。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.