列表图片缓存与加载优化

在Flutter框架中内置的图片缓存实现都是基于内存的,并没有进行本地文件持久化存储

默认情况,Flutter支持1000张的图片缓存到本地,并且这些图片的总计大小不得超过100MB

 PaintingBinding.instance.imageCache.maximumSize=2000; //最多2000张
 PaintingBinding.instance.imageCache.maximumSizeBytes = 200 << 20; //最大200M

图片缓存会对内存造成一定的压力所以,不建议内存缓存设置过大

图片本地缓存

cached_network_image新版本兼容性好官方推荐

列表常驻内存

默认情况下放在PageView中的页面切换走时会被销毁,在次切换回来会导致页面被重新创建,如果页面中有列表那么整个列表将被重新加载,降低用户体验,为解决问题问题可以通过让页面的
State实现AutomaticKeepAliveClientMixin:

补充:

在listView中, 默认listView预加载 屏幕1/3大小的元素

在超长列表中,如果出现卡顿情况.  由于Listview允许子元素高度不固定,所以ListView不知道自己总告诉是多少,所以用itemExtent手动告诉listView子元素高度. 可以大幅度提高性能

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值