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