本文主要是介绍关于下拉刷新、上拉加载的问题--RecyclerView-- SwipeToLoadLayout,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
RecyclerView-- SwipeToLoadLayout
关于页面数据加载的问题:下拉刷新,本次只介绍关于RecycleView的一个刷新框架SwipeToLoadLayout
(一)首先介绍下RecyclerView,RecyclerView相比ListView增加了很多新特性:(参考自https://blog.csdn.net/mynameishuangshuai/article/details/51153978)
• Adapter中的ViewHolder模式 - 对于ListView来说,通过创建ViewHolder来提升性能并不是必须的。因为ListView并没有严格的ViewHolder设计模式。但是在使用RecyclerView的时候,Adapter必须实现至少一个ViewHolder,必须遵循ViewHolder设计模式。
• 定制Item条目 - ListView只能实现垂直线性排列的列表视图,与之不同的是,RecyclerView可以通过设置RecyclerView.LayoutManager来定制不同风格的视图,比如水平滚动列表或者不规则的瀑布流列表。• Item动画 - 在ListView中没有提供任何方法或者接口,方便开发者实现Item的增删动画。相反地,可以通过设置RecyclerView的RecyclerView.ItemAnimator来为条目增加动画效果。
• 设置数据源 - 在LisView中针对不同数据封装了各种类型的Adapter,比如用来处理数组的ArrayAdapter和用来展示Database结果的CursorAdapter。相反地,在RecyclerView中必须自定义实现RecyclerView.Adapter并为其提供数据集合。
• 设置条目分割线 - 在ListView中可以通过设置android:divider属性来为两个Item间设置分割线。如果想为RecyclerView添加此效果,则必须使用RecyclerView.ItemDecoration,这种实现方式不仅更灵活,而且样式也更加丰富。
• 设置点击事件 - 在ListView中存在AdapterView.OnItemClickListener接口,用来绑定条目的点击事件。但是,很遗憾的是在RecyclerView中,并没有提供这样的接口,不过,提供了另外一个接口RcyclerView.OnItemTouchListener,用来响应条目的触摸事件。
但是……,RecyclerView不像ListView那样拥有Header和Footer,因此开发中需要我们自己去实现Header和Foote,另外开发中小伙伴们经常使用的PullToRefresh库暂时又不支持RecyclerView。
(二)SwipeToLoadLayout
GitHub地址:https://github.com/Aspsine/SwipeToLoadLayout
How to use it:
- Step 1. Add the JitPack repository in your build.gradle at the end of repositories:
repositories {maven { url "https://jitpack.io" }
}
- Step 2. Add the dependency in the form
dependencies {compile 'com.github.Aspsine:SwipeToLoadLayout:1.0.4'
}
- Step 3.Look overQuick Setupfor more details.You can find more customized header view and footer view in the demo app.
下次更新:SuperSwipeRefreshLayout(非浸入式下拉刷新、上拉加载)+实现SwipeRefreshLayout首次进入自动刷新
这篇关于关于下拉刷新、上拉加载的问题--RecyclerView-- SwipeToLoadLayout的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!