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()方法重寫(xiě),根據(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 table布局開(kāi)發(fā)實(shí)現(xiàn)簡(jiǎn)單計(jì)算器
這篇文章主要為大家詳細(xì)介紹了Android table布局開(kāi)發(fā)實(shí)現(xiàn)簡(jiǎn)單計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05
Flutter實(shí)現(xiàn)固定header底部滑動(dòng)頁(yè)效果示例
這篇文章主要為大家介紹了Flutter實(shí)現(xiàn)固定header底部滑動(dòng)頁(yè)效果示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
Android波紋擴(kuò)散效果之仿支付寶咻一咻功能實(shí)現(xiàn)波紋擴(kuò)散特效
這篇文章主要介紹了Android波紋擴(kuò)散效果之仿支付寶咻一咻功能實(shí)現(xiàn)波紋擴(kuò)散特效的相關(guān)資料,需要的朋友可以參考下2016-02-02
Android筆記之:深入為從右向左語(yǔ)言定義復(fù)雜字串的詳解
本篇文章是對(duì)Android中為從右向左語(yǔ)言定義復(fù)雜字串進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
Kotlin協(xié)程之Flow觸發(fā)與消費(fèi)示例解析
Kotlin協(xié)程中,當(dāng)需要消費(fèi)流時(shí),會(huì)調(diào)用collect方法,觸發(fā)流的消費(fèi),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2022-09-09
AndroidStudio升級(jí)到3.0的新特性和注意事項(xiàng)小結(jié)
這篇文章主要介紹了AndroidStudio升級(jí)到3.0的新特性和注意事項(xiàng),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-11-11
Android實(shí)現(xiàn)房貸計(jì)算器功能
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)房貸計(jì)算器功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01

