還在用Lisview?RecyclerView都已經(jīng)出來一年多了揭北!
想必大家多或多或少的接觸過或者了解過RecyclerView扳炬,為什么沒有用起來,原因大概如下搔体?
ListView我用的挺好的恨樟,為什么要換RecyclerView?
ListView穩(wěn)定疚俱,熟悉劝术,還知道很多開源庫,特別的好用计螺!
RecyclerView不能添加頭部夯尽,ListView能!
RecyclerView
在Andorid 5.0出來不久登馒,我就已經(jīng)寫過RecyclerView的簡(jiǎn)單介紹以及基本使用匙握,不了解的可以看看ListView升級(jí)版RecyclerView,了解過的同學(xué)可以忽略陈轿,并往下看圈纺。
RecyclerView最大的優(yōu)勢(shì)就是靈活,RecyclerView只需改變一行代碼就可以變化多種不同的布局顯示排版麦射,這一點(diǎn)對(duì)于開發(fā)者是非常方便的蛾娶!
RecyclerView.Adapter,比BaseAdapter做了更好的封裝潜秋,把BaseAdapter的getView方法拆分成onCreateViewHolder方法和onBindViewHolder方法蛔琅,強(qiáng)制需要?jiǎng)?chuàng)建ViewHolder,這樣的好處就是避免了初學(xué)者寫性能不佳的代碼
在實(shí)戰(zhàn)中我們會(huì)遇到什么問題峻呛?
get到下面的技能就能夠在使用RcyclerView的大路上暢通無阻了罗售!
添加分割線
添加點(diǎn)按效果
列表動(dòng)畫
改變某個(gè)數(shù)據(jù)保持當(dāng)前位置
添加頭部尾部
列表分組
各種效果集成Demo
更靈活的RecyclerView
添加分割線
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());
//通過以下方法添加分割線mRecyclerView.addItemDecoration();
HorizontalDividerItemDecoration需要繼承RecyclerView.ItemDecoration這個(gè)抽象類實(shí)現(xiàn)一些方法 。但是我感覺過于麻煩钩述,所以我想到的是:
直接在item_view里面底部自己添加一根線布局寨躁,這樣就無需重寫了,并且這樣還有個(gè)好處就是牙勘,如果細(xì)心的同學(xué)會(huì)發(fā)現(xiàn)职恳,添加分割線,最后一個(gè)item下面不會(huì)有分割線,顯然當(dāng)數(shù)據(jù)量不足一個(gè)屏幕的時(shí)候顯得很突兀放钦,但是在item_view下面添加一個(gè)線的布局則不會(huì)出現(xiàn)這種情況
添加點(diǎn)按效果
RecyclerView直接在item_view里面配置即可selector即可色徘。
動(dòng)畫
一個(gè)好的用戶體驗(yàn)就是要有操作動(dòng)畫的過渡,而不是生硬的刷新列表最筒。
推薦一個(gè)RecyclerView的動(dòng)畫庫(recyclerview-animators)
RecyclerView自帶添加贺氓、刪除動(dòng)畫,而ListView則需添加額外的代碼才能實(shí)現(xiàn)床蜘。
刪除調(diào)用RecyclerView的adapter的notifyItemRemoved
添加調(diào)用RecyclerView的adapter的notifyItemInserted
說到adapter我們就來說說RecyclerView.Adapter和BaseAdapter相比辙培,額外提供了一下這些方法:
// 數(shù)據(jù)發(fā)生了改變,那調(diào)用這個(gè)方法邢锯,傳入改變對(duì)象的位置扬蕊。publicfinalvoidnotifyItemChanged(intposition);// 可以刷新從positionStart開始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同樣的操作但是原來滑動(dòng)的位置不變翎冲。
各種解決方案的RecyclerView的Adapter
效果展示
布局更靈活的RecyclerView
twoway-view封裝了RecyclerView常用方法,如click等等,以及支持了更多不同的布局媳荒,使得RecyclerView使用起來更簡(jiǎn)單抗悍!
更靈活的添加分割線
分割線使用請(qǐng)參考 以下鏈接:
https://github.com/yqritc/RecyclerView-FlexibleDivider
部分文字引用了:陳宇明
參考鏈接:http://www.reibang.com/p/a92955be0a3e