前言
本文主要向大家介绍一个思路,用于解决在实际开发中,加载数据列表这个最基本的需求(你应该已经熟悉recyclerView的用法)。下面我们开始分析加载一个列表一般需要哪些需求。
需求
1.从服务器获取一段Json(当然也可以是其他格式的数据),比如:
{
"list":[
{"name":"zhang","age":20},
{"name":"li","age":10},
{"name":"wang","age":20},
{"name":"zhao","age":30}
]
}
2.新建Adapter,根据数据加载视图
3.一般需要下拉刷新、上拉加载分页数据
4.无数据时,各种花样的提示,网络错误时,各种花样的提示,譬如:
需求差不多就是这些,但是我们开发时实现还是标胶复杂的,比如:
- 获取到数据更新adapter
- 给SwipeRefreshLayout设置下拉监听,网络请求结束后关闭dialog
- 设置上拉加载函数,网络请求完成关闭上拉加载的状态
- 获取到的数据为空或者获取失败,显示相应的布局,重新请求成功再隐藏相应布局
- 网络请求成功后pageIndex++
- 如果分页大小是20,那么第一次获取的size小于20,就不能够上拉加载。
这些代码,起码得要个100行吧,写一次还好,要是动不动就写个一次
那么接下来就该我封装的自定义控件BaseRecyclerView登场了,先简单看一下用法:
神奇吧,这几行代码,上面所有的需求都被解决了?。?!
解释
之前提到的所有需求,都被封装在BaseRecyclerView里。BaseRecyclerView只对外提供了一个初始化的方法,传入Adapter,以及实现一个接口。Adapter是干嘛的我们都知道(如果对BaseRecyclerView不了解的同学可以先去了解一下,当然可以继续向下看,思路有了,ListView也可以封装一个类似的),重点说一下NetWorkHandle接口,这个接口里有两个需要实现的方法,一个是init方法,init方法的作用有在注释里写,主要是初始化配置:
然后是loadData方法:
public void loadData(boolean isRefresh, final String pageIndex)
这里面其实是使用了代理模式,我们无需关心在何时何地触发上拉操作和下拉操作,只需要知道,当用户下拉或者上拉时,会调用这个方法,isRefresh是true表示下拉刷新,false表示下拉加载,pageIndex表示页数,仅此而已。封装过程如下所示:
源码
有兴趣的查看具体实现细节,代码都很简单,主要就是经验的总结,另外这个项目里还有其他一些整理的东西。代码写的不是很好,欢迎提出改进建议。
项目地址:https://github.com/gg051202/android-frame
使用
-----------------------------------------------------分割线----------------------------------------------
抱歉,忘了贴文字了:
allprojects {
repositories {
maven { url 'https://jitpack.io' }
}
}
dependencies {
compile 'com.github.gg051202:android-frame:v0.2.8'
}
其实可以去这个网站 https://jitpack.io/,只要在搜索框里输入github项目的地址,就可以直接引用了,特别方便。比如你可以把别人一些很好的开源库fork到自己的仓库里,然后修改一些代码引用,或者自己写一些东西然后发布。