- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我从 Paging 2 迁移到 Paging 3 库,现在我使用 PagingSource
从服务器加载数据页面。但我无法理解 getRefreshKey
必须在那里重写的方法。我找到了一些代码示例,如何根据用于获取后续页面的 key 来实现它,但我仍然不明白。基于这些示例,我编写了以下代码:
override fun getRefreshKey(state: PagingState<Pair<String, String>, User>): Pair<String, String>? {
return state.anchorPosition?.let { anchorPosition ->
state.closestPageToPosition(anchorPosition)?.prevKey
}
}
但是,如果我让它始终返回 null,它不会改变任何事情:
override fun getRefreshKey(state: PagingState<Pair<String, String>, User>): Pair<String, String>? = null
那么为什么我不能选择最简单的解决方案呢?还是有我看不到的用例?
最佳答案
所以,这将是不同的:
假设您有工作 list 。用户正在滚动列表,并且列表中有一些变化(可以说数据已更新)。然后:
getRefreshKey() 总是返回 null 的情况:
随着你的数据更新,会有一对新的 PagingSource 和 PagingData,意思是 paging lib。将需要重新加载列表。如果 getRefreshKey() 返回 null,那么它将不知道上次访问的是哪个页面,并将用户返回到列表的开头(因为位置的键将由 load() 中的键决定)。
另一方面,如果正确实现了 getRefreshKey(),则:
分页库。会知道最后访问的位置,并且列表不会跳到顶部。相反,它将显示最后访问的页面。
关于android - 了解 PagingSource 的 getRefreshKey,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68567971/
我从 Paging 2 迁移到 Paging 3 库,现在我使用 PagingSource从服务器加载数据页面。但我无法理解 getRefreshKey必须在那里重写的方法。我找到了一些代码示例,如何
我正在尝试使用 GraphQL Relay spec 实现基于光标的分页(基于 Android Paging Library 3 ) ,但不知道如何实现 getRefreshKey . 这是我尝试过的
我是一名优秀的程序员,十分优秀!