美文网首页
如何优雅地实现RecyclerView Adapter多布局列表

如何优雅地实现RecyclerView Adapter多布局列表

作者: mazoxn | 来源:发表于2017-04-26 15:21 被阅读0次

作者简介  原创微信公众号鸿洋 WeChat ID: hongyangAndroid

现在在实际开发中,越来越多的人选择RecyclerView来实现列表布局,而RecyclerView写多了,每次都要直接继承Adapter实现onCreateViewHolder、onBindViewHolder、getItemCount这三个方法,虽然代码量不算很大,但每个XXXAdapter其实都长得差不多,这种重复性的代码,开发者是最不想写的了,所以网上就出现了很多封装Adapter的开源库。

所以本篇文章也介绍自己封装的一个Adapter,帮你快速高效的添加一个列表(包括单Item列表和多Item列表)。

先简单看一下最终效果:

而Adapter的代码量极少,感受一下:

嗯,没错,你只需要实现bind方法就可以了,而bind方法是用来设置View的一些一次性设置的,例如开启响应点击事件,长按事件等。所以上面我就什么都没写。

总体思路

实现一个通用的Adapter模版,避免写Adapter中大量的重复代码,抽象出几个接口。

通过让数据类实现IMultiItem接口,把部分Adapter中的代码转移到具体的数据类中,而不用在Adapter去判断数据类型和ViewType。这样很容易添加新的Item(ViewType)类型,减少耦合,Adapter不用去感知IMultiItem的具体类型。

高内聚,低耦合,方便扩展。

封装ViewHolder,将对View的常用操作都加上去。

2

实现

我们先看一下BaseViewHolder:BaseViewHolder封装了我们一些常用的操作,例如获取子View,设置item的点击事件,设置item的子View响应点击事件等。获取子View我用了Object[]数组进行缓存,没有用SparseArray来缓存View,主要是我之前看了Agera的源码,所以才用这种方式来缓存的,这里按下不表,下面是BaseAdapter的部分代码:

接下来我们来看一下BaseMultiAdapter里面做了什么?

是不是发现这里面也很少代码,因为很大一部分代码都在BaseAdapter中实现了,

这里我们发现了一个IMultiItem,我们看一下它俩的源代码:

BaseAdapter的代码如下:

看到这里我们就能发现了,BaseAdapter已经写了大部分的代码,就留下getLayoutRes,convert,bind给子类去实现,而它的子类BaseMultiAdapter直接把getLayoutRes和convert丢给了IMultiItem去实现。

getLayoutRes是返回item对应的布局文件id,同时它在BaseAdapter也作为ViewType来使用,所以如果是不同类型的item,不建议共用同个布局文件。

所以,我们的数据类只要实现IMultiItem接口即可,例如上面的文本类item:

把getLayoutRes跟convert交给IMultiItem处理的好处就是实现多布局列表变得很简单,数据各自对应自己的布局文件,自己在convert方法中显示数据。

源码

上面的具体全部代码在都在我的开源库里,一个封装了RecyclerView.Adapter一些常用功能的库:

https://github.com/EvilBT/SherlockAdapter

相关文章

网友评论

      本文标题:如何优雅地实现RecyclerView Adapter多布局列表

      本文链接:https://www.haomeiwen.com/subject/pmjizttx.html