Android開(kāi)發(fā)RecyclerView單獨(dú)刷新使用技巧
單刷RecycleView的子Item
除非必要,應(yīng)該盡可能避免調(diào)用notifyDataSetChanged()
去刷新RecyclerView
列表 ,這會(huì)對(duì)性能造成影響,所以RecyclerView.Adapter
還提供了一下幾個(gè)方法:
private fun recycleViewRelated() { mAdapter.notifyItemChanged() mAdapter.notifyItemRangeChanged() mAdapter.notifyItemInserted() mAdapter.notifyItemRangeInserted() mAdapter.notifyItemRangeRemoved() mAdapter.notifyItemRemoved() }
notifyItemXXXChanged()
:通知指定索引的item調(diào)用onBindViewHolder()
刷新界面
notifyItemXXXInserted()
:通知在指定索引處插入item,即插入ViewHolder,有可能復(fù)用,有可能重新調(diào)用onCreateViewHolder()
創(chuàng)建
notifyItemXXXRemoved()
: 通知移除指定索引的item,即移除ViewHolder,并根據(jù)情況放到大家了解的1級(jí)mAttachedScrap
緩存或3級(jí)緩存RecycledViewPool
中
上面的幾個(gè)情況大家根據(jù)情況調(diào)用,請(qǐng)注意調(diào)用上面單刷方法時(shí),同樣要保證RecyclerView
數(shù)據(jù)源也進(jìn)行了插入/刪除/更新操作
,否則可能會(huì)引發(fā)不必要的異常。
單刷RecycleView的子Item的局部?jī)?nèi)容
有時(shí)候,某個(gè)子Item對(duì)應(yīng)的布局比較復(fù)雜,且每次刷新只可能會(huì)刷新其中一部分,這個(gè)時(shí)候使用上面介紹的單刷就會(huì)刷新到子item中不必要刷新的部分,這個(gè)時(shí)候我們可以借助payload
實(shí)現(xiàn)單刷Item中的某一部分內(nèi)容。
接下來(lái)介紹兩種方式,假設(shè)當(dāng)前Item布局如下,當(dāng)前只想刷新頂部?jī)?nèi)容
:
1.普通payload方式
這個(gè)主要是借助帶payload
參數(shù)的notifyItemXXXRemoved/Changed/Inserted()
方法+帶payloads
參數(shù)的onBindViewHolder()
方法實(shí)現(xiàn),接下來(lái)我們來(lái)看代碼實(shí)操。
我們用1、2、3分別來(lái)標(biāo)識(shí)Item的頂部、中部和底部對(duì)應(yīng)布局內(nèi)容,目前我們只想刷新標(biāo)識(shí)為1對(duì)應(yīng)的頂部?jī)?nèi)容:
mAdapter.notifyItemChanged(0, 1)
上面代碼就代表著刷新下標(biāo)為0對(duì)應(yīng)item布局的頂部?jī)?nèi)容,接下來(lái)我們?cè)?code>onBindViewHolder() 中處理:
override fun onBindViewHolder( holder: RecyclerView.ViewHolder, position: Int, payloads: MutableList<Any> ) { if (payloads.isEmpty()) { super.onBindViewHolder(holder, position, payloads) return } when(payloads[0]) { //刷新頂部?jī)?nèi)容 1 -> {} //刷新中部?jī)?nèi)容 2 -> {} //刷新底部?jī)?nèi)容 3 -> {} } }
得用帶有如上payloads
參數(shù)的onBindViewHolder()
才能處理通過(guò)notifyItemChanged()
最后一個(gè)參數(shù)傳遞過(guò)來(lái)的payload
參數(shù)。
請(qǐng)注意當(dāng)payloads
集合參數(shù)為空時(shí),要主動(dòng)調(diào)用super.onBindViewHolder(holder, position, payloads)
保證單item的整體刷新。
2.ListAdapter方式
ListAdapter
是基于DiffUtil
實(shí)現(xiàn)列表中部分item刷新的,具體的使用這里不做過(guò)多介紹。
當(dāng)我們繼承ListAdapter
自定義一個(gè)適配器時(shí),要傳入一個(gè)DiffUtil.ItemCallback
對(duì)象,這個(gè)對(duì)象有個(gè)getChangePayload()
方法,這里就是實(shí)現(xiàn)item中局部?jī)?nèi)容刷新的關(guān)鍵。
private class InnerAdapter2 : ListAdapter<String, RecyclerView.ViewHolder>(object : DiffUtil.ItemCallback<String>() { override fun areItemsTheSame(oldItem: String, newItem: String): Boolean { } override fun areContentsTheSame(oldItem: String, newItem: String): Boolean { } override fun getChangePayload(oldItem: String, newItem: String): Any? { return super.getChangePayload(oldItem, newItem) } })
我們只需要對(duì)上面的getChangePayload()
方法重寫,根據(jù)數(shù)據(jù)變更的范圍來(lái)決定刷新item的頂部、中部還是底部。
override fun getChangePayload(oldItem: String, newItem: String): Any? { val list = mu //如果數(shù)據(jù)變更會(huì)影響item頂部?jī)?nèi)容顯示,則返回1刷新item頂部?jī)?nèi)容 if (oldItem != newItem) { return 1 } //如果數(shù)據(jù)變更會(huì)影響item頂部?jī)?nèi)容顯示,則返回2刷新item中部?jī)?nèi)容 if (oldItem != newItem) { return 2 } //如果數(shù)據(jù)變更會(huì)影響item頂部?jī)?nèi)容顯示,則返回3刷新item底部?jī)?nèi)容 if (oldItem != newItem) { return 3 } return super.getChangePayload(oldItem, newItem) }
接下來(lái)我們?cè)?code>onBindViewHolder中處理就行 ,處理的方式和上面相同,這里就再描述。
如果我們想要同時(shí)實(shí)現(xiàn)item中頂部和底部布局內(nèi)容的同時(shí)刷新,那就可以向onBindViewHolder()
的payload中傳一個(gè)集合包含1和3標(biāo)識(shí)或者其他特殊標(biāo)識(shí)等等,方式不限,只要能讓onBindViewHolder()
知道要刷新頂部和底部就即可。
總結(jié)
本篇文章主要是講解了如何實(shí)現(xiàn)RecyclerView
中子item如何單獨(dú)刷新以及子item的某一部分內(nèi)容如何實(shí)現(xiàn)單獨(dú)刷新,沒(méi)什么難度,大家知道并學(xué)會(huì)運(yùn)用即可,更多關(guān)于Android RecyclerView單獨(dú)刷新的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- PopupWindow?RecyclerView實(shí)現(xiàn)下拉選擇Spinner示例解析
- Android開(kāi)發(fā)RecyclerView性能優(yōu)化之異步預(yù)加載
- RecyclerView無(wú)限循環(huán)效果實(shí)現(xiàn)及示例解析
- Android 源碼淺析RecyclerView ItemAnimator
- RecyclerView 源碼淺析測(cè)量 布局 繪制 預(yù)布局
- Android?源碼淺析RecyclerView?Adapter
- RecyclerView多層級(jí)數(shù)據(jù)實(shí)現(xiàn)示例詳解
相關(guān)文章
Android實(shí)現(xiàn)設(shè)置APP灰白模式效果
大家好,本篇文章主要講的是Android實(shí)現(xiàn)設(shè)置APP灰白模式效果,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下,方便下次瀏覽2021-12-12Android實(shí)現(xiàn)循環(huán)輪播跑馬燈的效果
這篇文章主要介紹了為大家詳細(xì)介紹了如何通過(guò)Android實(shí)現(xiàn)循環(huán)輪播跑馬燈的效果,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-05-05Android持久化技術(shù)之SharedPreferences存儲(chǔ)實(shí)例詳解
這篇文章主要介紹了Android持久化技術(shù)之SharedPreferences存儲(chǔ),結(jié)合實(shí)例形式較為詳細(xì)的分析了SharedPreferences存儲(chǔ)的原理、應(yīng)用及具體實(shí)現(xiàn)方法,需要的朋友可以參考下2016-01-01詳解Android studio 3+版本apk安裝失敗問(wèn)題
這篇文章主要介紹了詳解Android studio 3+版本apk安裝失敗問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04Android 使用FragmentTabhost代替Tabhost
這篇文章主要介紹了Android 使用FragmentTabhost代替Tabhost的相關(guān)資料,需要的朋友可以參考下2017-05-05Android利用Intent實(shí)現(xiàn)讀取圖片操作
這篇文章主要為大家詳細(xì)介紹了Android利用Intent實(shí)現(xiàn)讀取圖片操作的相關(guān)資料,感興趣的小伙伴們可以參考一下2016-06-06SQLite數(shù)據(jù)庫(kù)在Android中的使用小結(jié)
SQLIte是一款輕型的數(shù)據(jù)庫(kù),占用資源非常低,在嵌入式設(shè)備中,可能只需幾百k的內(nèi)存,這篇文章主要介紹了SQLite數(shù)據(jù)庫(kù)在Android中的使用,需要的朋友可以參考下2024-07-07