還在用Lisview?RecyclerView都已經(jīng)出來(lái)一年多了!
想必大家多或多或少的接觸過(guò)或者了解過(guò)RecyclerView,為什么沒(méi)有用起來(lái),原因大概如下?
ListView我用的挺好的,為什么要換RecyclerView?
ListView穩(wěn)定,熟悉,還知道很多開(kāi)源庫(kù),特別的好用!
RecyclerView不能添加頭部,ListView能!
RecyclerView
在Andorid 5.0出來(lái)不久,我就已經(jīng)寫(xiě)過(guò)RecyclerView的簡(jiǎn)單介紹以及基本使用,不了解的可以看看ListView升級(jí)版RecyclerView,了解過(guò)的同學(xué)可以忽略,并往下看。
RecyclerView最大的優(yōu)勢(shì)就是靈活,RecyclerView只需改變一行代碼就可以變化多種不同的布局顯示排版,這一點(diǎn)對(duì)于開(kāi)發(fā)者是非常方便的!
RecyclerView.Adapter,比BaseAdapter做了更好的封裝,把BaseAdapter的getView方法拆分成onCreateViewHolder方法和onBindViewHolder方法,強(qiáng)制需要?jiǎng)?chuàng)建ViewHolder,這樣的好處就是避免了初學(xué)者寫(xiě)性能不佳的代碼
在實(shí)戰(zhàn)中我們會(huì)遇到什么問(wèn)題?
get到下面的技能就能夠在使用RcyclerView的大路上暢通無(wú)阻了!
添加分割線(xiàn)
添加點(diǎn)按效果
列表動(dòng)畫(huà)
改變某個(gè)數(shù)據(jù)保持當(dāng)前位置
添加頭部尾部
列表分組
各種效果集成Demo
更靈活的RecyclerView
添加分割線(xiàn)
RecyclerViewrecyclerView=(RecyclerView) findViewById(R.id.recyclerview);
recyclerView.addItemDecoration(new HorizontalDividerItemDecoration.Builder(this)
?.color(Color.RED)
?.sizeResId(R.dimen.divider)
.marginResId(R.dimen.leftmargin,R.dimen.rightmargin)
.build());
//通過(guò)以下方法添加分割線(xiàn)mRecyclerView.addItemDecoration();
HorizontalDividerItemDecoration需要繼承RecyclerView.ItemDecoration這個(gè)抽象類(lèi)實(shí)現(xiàn)一些方法 。但是我感覺(jué)過(guò)于麻煩,所以我想到的是:
直接在item_view里面底部自己添加一根線(xiàn)布局,這樣就無(wú)需重寫(xiě)了,并且這樣還有個(gè)好處就是,如果細(xì)心的同學(xué)會(huì)發(fā)現(xiàn),添加分割線(xiàn),最后一個(gè)item下面不會(huì)有分割線(xiàn),顯然當(dāng)數(shù)據(jù)量不足一個(gè)屏幕的時(shí)候顯得很突兀,但是在item_view下面添加一個(gè)線(xiàn)的布局則不會(huì)出現(xiàn)這種情況
添加點(diǎn)按效果
RecyclerView直接在item_view里面配置即可selector即可。
動(dòng)畫(huà)
一個(gè)好的用戶(hù)體驗(yàn)就是要有操作動(dòng)畫(huà)的過(guò)渡,而不是生硬的刷新列表。
推薦一個(gè)RecyclerView的動(dòng)畫(huà)庫(kù)(recyclerview-animators)
RecyclerView自帶添加、刪除動(dòng)畫(huà),而ListView則需添加額外的代碼才能實(shí)現(xiàn)。
刪除調(diào)用RecyclerView的adapter的notifyItemRemoved
添加調(diào)用RecyclerView的adapter的notifyItemInserted
說(shuō)到adapter我們就來(lái)說(shuō)說(shuō)RecyclerView.Adapter和BaseAdapter相比,額外提供了一下這些方法:
// 數(shù)據(jù)發(fā)生了改變,那調(diào)用這個(gè)方法,傳入改變對(duì)象的位置。publicfinalvoidnotifyItemChanged(intposition);// 可以刷新從positionStart開(kāi)始itemCount數(shù)量的item了publicfinalvoidnotifyItemRangeChanged(intpositionStart,intitemCount);// 添加,傳入對(duì)象的位置。publicfinalvoidnotifyItemInserted(intposition);// 刪除,傳入對(duì)象的位置。publicfinalvoidnotifyItemRemoved(intposition);// 對(duì)象從fromPosition移動(dòng)到toPositionpublicfinalvoidnotifyItemMoved(intfromPosition,inttoPosition);//批量添加publicfinalvoidnotifyItemRangeInserted(intpositionStart,intitemCount);//批量刪除publicfinalvoidnotifyItemRangeRemoved(intpositionStart,intitemCount);
改變列表某個(gè)布局狀態(tài)且保持當(dāng)前位置
這種需求是普遍存在的,就是改變列表某一個(gè)item數(shù)據(jù),然后刷新列表,如果是ListView刷新后則會(huì)回到最頂部,而RecyclerView同樣的操作但是原來(lái)滑動(dòng)的位置不變。
各種解決方案的RecyclerView的Adapter

效果展示
布局更靈活的RecyclerView
twoway-view封裝了RecyclerView常用方法,如click等等,以及支持了更多不同的布局,使得RecyclerView使用起來(lái)更簡(jiǎn)單!
更靈活的添加分割線(xiàn)
分割線(xiàn)使用請(qǐng)參考 以下鏈接:
https://github.com/yqritc/RecyclerView-FlexibleDivider
部分文字引用了:陳宇明
參考鏈接:http://www.itdecent.cn/p/a92955be0a3e