RecyclerView优化:AsyncListUtil的使用

AsyncListUtil 可以异步加载数据,并根据列表滑动会自动分页加载,数据加载完成会回调主线程更新UI,并且可以在Item离屏后实现Recycle

缺陷

  • refreshData()方法需要指定数据总条数,只能在调用AsyncListUtil.refresh()方法时指定,无法动态设置数据总数,如果是接口获取数据,必须已知数据总条数
  • fillData(data: Array<T>, startPosition: Int, itemCount: Int)方法分页加载给出了startPosition和itemCount,也就限定了分页一定是有页码的,可以明确根据startPosition获取下一页数据,无法根据时间戳或者其他标识动态获取下一页数据
  • AsyncListUtil在初始化时指定了分页大小,也就限定了分页加载大小,无法根据浏览情况,动态设置分页加载大小
  • 调用AsyncListUtil.refresh()后默认还在当前分页index,如果想要回到第一页,需要自己维护逻辑;

注意

AsyncListUtil.refresh()方法只是刷新当前页面可见数据,并不会回到首页;

适用场景

  • 异步加载数据库数据,可以已知总条数,并能分页加载;
  • 分页接口已知数据总数,分页大小固定;

示例

class AsyncListUtilActivity : AppCompatActivity() {
   

    override fun onCreate(savedInstanceState: Bundle?) {
   
        super.onCreate(savedInstanceState)
        setContentView(R.layout.activity_recyclerview)

        supportActionBar!!.title = "RecyclerView"
        initView()
    }

    private fun initView() {
   
        val adapter = AsyncAdapter()
        recyclerView?.apply {
   
            this.layoutManager = LinearLayoutManager(this.context, RecyclerView.VERTICAL, false)
            val horizontalItemDecoration = DividerItemDecoration(this.context, DividerItemDecoration.HORIZONTAL)
            horizontalItemDecoration.setDrawable(this.context.resources.getDrawable(android.R.drawable.divider_horizontal_textfield))
            this.addItemDecoration(horizontalItemDecoration)
            this.adapter = adapter
            addOnScrollListener(ScrollListener
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值