首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Flutter-ListView组件下拉刷新+滚动底部加载+缓存封装

Flutter的ListView组件,虽然很好用,但是数据量大的时候,在低配置的机器上会奇卡无比,所以我封装了一个ListView组件,对数据进行截断,并使用 keframe 插件进行流畅性优化,提升低配置设备的用户体验.../flutter_easyloading.dart';//后续去除 import 'package:keframe/size_cache_widget.dart'; /// 可缓存+下拉刷新+滚动到底部自动加载的...ListView组件(返回数据定义复杂是方便局部刷新) class CacheTableList extends StatefulWidget { List tableList; double...Function createList; //自定义的item建立事件 Function getMoreData; //需返回完整的待渲染tablelist,返回null表示无更多数据,方便组件局部刷新...fontSize: 15, color: Colors.black38, fontWeight: FontWeight.bold), ), ) : ListView.builder

73010
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    解决ListView嵌套ListView遇到的问题

    Listview嵌套会造成的问题主要是子listview的高度错误导致内容不能正常显示完,解决这个问题,我个人第一个想法就是重新计算子listview的高度,代码如下: private void setListViewHeightBasedOnChildren...(ListView listView) { if(listView == null) return; ListAdapter listAdapter = listView.getAdapter...listView.setLayoutParams(params); } 父listview的adapter中getview方法调用 RelationAdapter relationAdapter...cell.xlistView.setAdapter(relationAdapter);setListViewHeightBasedOnChildren(cell.xlistView); 注意事项: Adapter中getView方法返回的View...的必须由LinearLayout组成,因为只有LinearLayout才有measure()方法,如果使用其他的布局如RelativeLayout,在调用listItem.measure(0, 0);时就会抛异常

    1.6K60

    listview的工作原理

    onDraw()在ListView当中也没有什么意义,因为ListView本身并不负责绘制,而是由ListView当中的子元素来进行绘制的。...ListView顶部的像素值,pos则是刚刚传入的mFirstPosition的值,而end是ListView底部减去顶部所得的像素值,mItemCount则是Adapter中的元素数量。...然后在第84行会进行判断,如果ListView中最后一个View的底部已经移入了屏幕,或者ListView中第一个View的顶部移入了屏幕,就会调用fillGap()方法,那么因此我们就可以猜出fillGap...ListView顶部的像素值,pos则是刚刚传入的mFirstPosition的值,而end是ListView底部减去顶部所得的像素值,mItemCount则是Adapter中的元素数量。...然后在第84行会进行判断,如果ListView中最后一个View的底部已经移入了屏幕,或者ListView中第一个View的顶部移入了屏幕,就会调用fillGap()方法,那么因此我们就可以猜出fillGap

    2.4K100

    ListView的相关总结

    Android的ListView可以算是最古老的UI控件了, 但是它有很多设计上的思想可以借鉴学习。...LitView的使用 回顾一下, ListView的使用其实非常简单, 只需要提供一个 UI,提供一个装载数据的 Adapter, 在 Adapter的 getView 方法里实现每个 item需要渲染的...我们先回想一个问题, 假设一个列表有 1000 个数据, 那么是否是说 ListView 就有 1000 条 UI呢? 结果当然是否定的, 这样对于内存和CPU是极大的浪费。...ListView的优化 通常在 Android初级的面试中会涉及到这个问题, 就是如何优化 ListView, 一般由浅到深的思路是这样的, · 复用 convertView · 自定义 ViewHolder...用 RecyclerView 替代 ListView ListView的局限 其实 ListView的局限很明显, 最简单的是它不能提前渲染 item, 这就造成当我们尝试用异步的方式来延迟渲染的时候有可能会让

    40620

    android入门 — ListView的优化

    ListView的运行效率是比较低的,因为在getView()中每次都会将整个布局重新加载一遍,当ListView快速滚动的时候就会成为性能瓶颈。   ...调用View中的findViewById()方法获取一次控件的实例,这也是一个很耗时的操作,可以进行优化。...在getView()方法进行判断,如果为空,则使用LayoutInflater去加载布局,如果不为空,则直接对convertView进行重用,这样可以提高ListView的运行效率,在快速滚动的时候也可以表现出更好的性能...当convertView不为空的时候:调用View的getTag()方法,将ViewHolder重新取出来。 ?   ...结论:     无论总量是多少,findViewById方法最多可以调用N+1组(N为一屏可以显示的item的数量)   通过ViewHolder的方法,可以将所有的控件进行缓存,不需要每次通过findViewById

    925130

    Android ListView组件的使用

    ListView是Android开发中非常常用的组件,ListView可以用来显示一个列表,我们可以对这个列表操作,比如点击列表要做什么等等。这篇文章主要通过一个示例来展示ListView的用法。...这里主要的是使用了一个Adapter—适配器,你可以把他看成是ListView的数据源,ListView要展示的数据都是已Adapter的形势传递给ListView的。...二:使用xml来自定义ListView 上个例子我们并没有使用在main.xml中定义一个ListView的形势来布局ListView,而是使用的ListActivity中默认的ListView来演示的...下面就使用我们在main.xml中自定义的ListView,这样我们可以很方便的控制ListView展示的布局,大小,背景色等属性。...五、小结 到这里ListView应该算是会使用了,起码常用的功能会的,当然还有很多没有说到的,比如ListView的分割部分,headView和footView以及ListView的分页等等,这些就需要我们自己下去好好摸索了

    1.2K10
    领券