網站首頁 編程語言 正文
單刷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()
創建
notifyItemXXXRemoved()
: 通知移除指定索引的item,即移除ViewHolder,并根據情況放到大家了解的1級mAttachedScrap
緩存或3級緩存RecycledViewPool
中
上面的幾個情況大家根據情況調用,請注意調用上面單刷方法時,同樣要保證RecyclerView
數據源也進行了插入/刪除/更新操作
,否則可能會引發不必要的異常。
單刷RecycleView的子Item的局部內容
有時候,某個子Item對應的布局比較復雜,且每次刷新只可能會刷新其中一部分,這個時候使用上面介紹的單刷就會刷新到子item中不必要刷新的部分,這個時候我們可以借助payload
實現單刷Item中的某一部分內容。
接下來介紹兩種方式,假設當前Item布局如下,當前只想刷新頂部內容
:
1.普通payload方式
這個主要是借助帶payload
參數的notifyItemXXXRemoved/Changed/Inserted()
方法+帶payloads
參數的onBindViewHolder()
方法實現,接下來我們來看代碼實操。
我們用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
參數的onBindViewHolder()
才能處理通過notifyItemChanged()
最后一個參數傳遞過來的payload
參數。
請注意當payloads
集合參數為空時,要主動調用super.onBindViewHolder(holder, position, payloads)
保證單item的整體刷新。
2.ListAdapter方式
ListAdapter
是基于DiffUtil
實現列表中部分item刷新的,具體的使用這里不做過多介紹。
當我們繼承ListAdapter
自定義一個適配器時,要傳入一個DiffUtil.ItemCallback
對象,這個對象有個getChangePayload()
方法,這里就是實現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()
方法重寫,根據數據變更的范圍來決定刷新item的頂部、中部還是底部。
override fun getChangePayload(oldItem: String, newItem: String): Any? { val list = mu //如果數據變更會影響item頂部內容顯示,則返回1刷新item頂部內容 if (oldItem != newItem) { return 1 } //如果數據變更會影響item頂部內容顯示,則返回2刷新item中部內容 if (oldItem != newItem) { return 2 } //如果數據變更會影響item頂部內容顯示,則返回3刷新item底部內容 if (oldItem != newItem) { return 3 } return super.getChangePayload(oldItem, newItem) }
接下來我們在onBindViewHolder
中處理就行 ,處理的方式和上面相同,這里就再描述。
如果我們想要同時實現item中頂部和底部布局內容的同時刷新,那就可以向onBindViewHolder()
的payload中傳一個集合包含1和3標識或者其他特殊標識等等,方式不限,只要能讓onBindViewHolder()
知道要刷新頂部和底部就即可。
總結
原文鏈接:https://juejin.cn/post/7145856146740346916
相關推薦
- 2023-02-04 python?配置uwsgi?啟動Django框架的詳細教程_python
- 2022-09-25 spring如何解決循環依賴
- 2022-12-25 Flutter開發通用頁面Loading組件示例詳解_Android
- 2023-02-10 docker的鏡像存放地址在哪里_docker
- 2024-03-24 spring boot 3 + spring cloud sleuth 無法注入Tracer問題
- 2022-06-08 Flutter集成高德地圖并添加自定義Maker的實踐_Android
- 2022-11-02 Kotlin中@JvmOverloads注解作用示例介紹_Android
- 2022-09-21 Django中外鍵使用總結_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支