- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我尝试以正常方式添加标题(不同的 View 类型、将数据计数增加 1 等),但分页列表滚动条跳到列表底部。
此后我遇到了the AsyncPagedListDiffer并尝试实现它,但现在除了标题之外我的所有项目都消失了。谁能看出我做错了什么吗?
class MerchantHistoryAdapter : PagedListAdapter<MerchantHistoryResponse.Transaction, BaseViewHolder>(MerchantHistoryDiffUtilCallback()) {
lateinit var listener: HistoryItemListAdapterListener
lateinit var headerListener: HistoryItemHeaderListAdapterListener
lateinit var networkStateListener: NetworkStateListAdapterListener
private var networkState: NetworkState = NetworkState.LOADING
val adapterCallback = AdapterListUpdateCallback(this)
val listUpdateCallback = object : ListUpdateCallback {
override fun onInserted(position: Int, count: Int) {
adapterCallback.onInserted(position + 1, count)
}
override fun onRemoved(position: Int, count: Int) {
adapterCallback.onRemoved(position + 1, count)
}
override fun onMoved(fromPosition: Int, toPosition: Int) {
adapterCallback.onMoved(fromPosition + 1, toPosition + 1)
}
override fun onChanged(position: Int, count: Int, payload: Any?) {
adapterCallback.onChanged(position + 1, count, payload)
}
}
val differ = AsyncPagedListDiffer<MerchantHistoryResponse.Transaction>(listUpdateCallback,
AsyncDifferConfig.Builder<MerchantHistoryResponse.Transaction>(MerchantHistoryDiffUtilCallback()).build())
override fun getItem(position: Int): MerchantHistoryResponse.Transaction? {
return differ.getItem(position - 1)
}
override fun submitList(pagedList: PagedList<MerchantHistoryResponse.Transaction>?) {
differ.submitList(pagedList)
}
override fun getCurrentList(): PagedList<MerchantHistoryResponse.Transaction>? {
return differ.currentList
}
override fun onBindViewHolder(holder: BaseViewHolder, position: Int) {
holder.onBind(position)
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): BaseViewHolder {
return when (viewType) {
R.layout.item_merchant_history_header -> {
val view = ItemMerchantHistoryHeaderBinding.inflate(LayoutInflater.from(parent.context))
MerchantHistoryHeaderViewHolder(view)
}
R.layout.item_merchant_history -> {
val view = ItemMerchantHistoryBinding.inflate(LayoutInflater.from(parent.context))
MerchantHistoryViewHolder(view)
}
R.layout.item_network_state -> {
val view = ItemNetworkStateBinding.inflate(LayoutInflater.from(parent.context))
NetworkStateViewHolder(view)
}
else -> throw IllegalArgumentException("unknown view type $viewType")
}
}
override fun getItemViewType(position: Int): Int {
return if(position == 0){
R.layout.item_merchant_history_header
}
else if (hasExtraRow() && position == itemCount - 1) {
R.layout.item_network_state
} else {
R.layout.item_merchant_history
}
}
private fun hasExtraRow() = networkState != null && networkState != NetworkState.LOADED
override fun getItemCount(): Int {
//Header item, plus the extra row
return super.getItemCount() + if (hasExtraRow()) 2 else 1
}
fun setNetworkState(newNetworkState: NetworkState) {
Timber.d("Setting network state....." + newNetworkState.status)
val previousState = this.networkState
val hadExtraRow = hasExtraRow()
this.networkState = newNetworkState
val hasExtraRow = hasExtraRow()
if (hadExtraRow != hasExtraRow) {
if (hadExtraRow) {
notifyItemRemoved(differ.itemCount + 1)
} else {
notifyItemInserted(differ.itemCount + 1)
}
} else if (hasExtraRow && previousState != newNetworkState) {
notifyItemChanged(itemCount - 1)
}
}
inner class MerchantHistoryViewHolder(private val binding: ItemMerchantHistoryBinding)
: BaseViewHolder(binding.root), MerchantHistoryItemViewModel.ListItemViewModelListener {
private var itemViewModel: MerchantHistoryItemViewModel? = null
override fun onBind(position: Int) {
val transaction = getItem(position)
transaction?.let {
itemViewModel = MerchantHistoryItemViewModel(binding.root.context, it, this)
binding.viewModel = itemViewModel
binding.executePendingBindings()
}
}
override fun onItemClick(item: MerchantHistoryResponse.Transaction) {
listener.onItemClick(item)
}
}
interface HistoryItemListAdapterListener {
fun onItemClick(item: MerchantHistoryResponse.Transaction)
}
inner class NetworkStateViewHolder(private val binding: ItemNetworkStateBinding)
: BaseViewHolder(binding.root), NetworkStateItemViewModel.ListItemViewModelListener {
private var itemViewModel: NetworkStateItemViewModel? = null
override fun onBind(position: Int) {
Timber.d("binding position " + position + " with network state of " + networkState.status)
itemViewModel = NetworkStateItemViewModel(binding.root.context, networkState,this)
binding.viewModel = itemViewModel
binding.executePendingBindings()
}
override fun onRetryClick() {
networkStateListener.onRetryClick()
}
}
interface NetworkStateListAdapterListener {
fun onRetryClick()
}
inner class MerchantHistoryHeaderViewHolder(private val binding: ItemMerchantHistoryHeaderBinding)
: BaseViewHolder(binding.root), MerchantHistoryHeaderItemViewModel.ListItemViewModelListener {
private var itemViewModel: MerchantHistoryHeaderItemViewModel? = null
override fun onBind(position: Int) {
itemViewModel = MerchantHistoryHeaderItemViewModel(binding.root.context, this)
binding.viewModel = itemViewModel
binding.executePendingBindings()
}
override fun onItemClick() {
headerListener.onItemClick()
}
}
interface HistoryItemHeaderListAdapterListener {
fun onItemClick()
}
class MerchantHistoryDiffUtilCallback : DiffUtil.ItemCallback<MerchantHistoryResponse.Transaction>() {
override fun areItemsTheSame(oldItem: MerchantHistoryResponse.Transaction, newItem: MerchantHistoryResponse.Transaction): Boolean {
return oldItem.uid == newItem.uid
}
override fun areContentsTheSame(oldItem: MerchantHistoryResponse.Transaction, newItem: MerchantHistoryResponse.Transaction): Boolean {
return oldItem.uid == newItem.uid
}
}
}
最佳答案
哈哈,好吧,我在发布后很快就明白了:
这个:
override fun getItemCount(): Int {
//Header item, plus the extra row
return super.getItemCount() + if (hasExtraRow()) 2 else 1
}
应该是:
override fun getItemCount(): Int {
//Header item, plus the extra row
return differ.itemCount + if (hasExtraRow()) 2 else 1
}
希望这对 future 的 Google 用户有所帮助。
关于android - 如何使用 Android 分页库向 PagedList 添加 header ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57853321/
我在让“@header”或任何其他@规则在ANTLR中工作时遇到麻烦。具有非常基本的语法,如下所示: grammar test; options { language = CSharp2;
我对来源和寄宿有疑问 我有一个ajax页面“Page A”,它将称为ajax提要“Page B” 我看到来自ajax调用的“页面B”的请求 header 具有源“http://mydomain.com
我在 pandas 中使用了数据透视表并获得了所需的数据框格式,但现在我有两行标题。数据透视表后的结果数据框如下: scenario Actual Plan
我在 pandas 中使用了数据透视表并获得了所需的数据框格式,但现在我有两行标题。数据透视表后的结果数据框如下: scenario Actual Plan
我想在主机将它们发送到网络之前修改数据包头(IP 头、TCP 头)。 例如,如果我使用 firefox 进行浏览,那么我想拦截所有来自 firefox 的数据包并修改 IP/TCP header ,然
我的 header 内容被包装到#header 中,但是当我设置边框显示结构时,它显示我的#header 的内容出现在#header 本身之后。可能是什么问题?这是我的代码: #header { bo
我是一名 Web 开发人员,使用过 PHP 和 .NET。有一年多的 Web 工作经验,我一直无法彻底了解浏览器缓存功能,希望这里的 Web Gurus 可以帮助我。我心中的问题是: 浏览器实际上是如
伙计们,我有一个问题,我不知道如何在一个 header 中连接多个 header ,我们称它为“主 header ”并使用该 header 中的函数,例如 // A.h #include class
我有一个包含 SOAP 消息的 XMLHTTPRequest。 我想添加用于标识消息并将由 C# Web 服务使用的 guid。 GUID 的目标是识别特定用户,并应护送所有用户请求以在服务器上进行身
我一直在阅读粘性标题,这是我目前所发现的。第一个粘性 header 效果很好,但是当它遇到第一个 header 时,我如何向上滚动第一个 header 并使第二个 header 卡住? http://
我想将当前基于 TableView 的数据网格转换为新的 UICollectionView 类。 这就是我当前的网格的样子: 我的网格有两个标题: 年份(2006a、2007a 等)和 类型(“收入”
我目前正在使用 Apollo 服务器。我正在尝试在响应 header 中设置一个属性。并且此属性是从客户端 graphQL 请求 header 中检索的。 我在网上查了一下。并看到了诸如使用插件或扩展
我的 Controller 的方法需要设置一个标题,例如X-Authorization .创建新对象( store Action )后,我执行转发以显示新创建的对象( show Action ): $
我正在研究一些关于 VLAN 的事情,发现了 VLAN 标签 和 header 。 如果我们有标准 802.3 以太网帧 的 MTU(1518 字节), header 802.3 中包含什么? 另外,
我是放心和 Java 的新手,我正在尝试做一个非常基本的测试来检查 API 的响应是否为 200 ok。 谁能告诉我我需要在下面的脚本中更改什么才能传递多个 header Id、Key 和 ConId
在我的项目中,我需要知道 zlib header 是什么样的。我听说它相当简单,但我找不到 zlib header 的任何描述。 例如,它是否包含魔数(Magic Number)? 最佳答案 zlib
我正在使用 JMeter 测试 HTTP 服务器,该服务器接受并验证 APIKey 并在成功时返回一个有时限的 token 。如果我有 token ,我想发送一个 token ;如果没有,我想发送一个
以太网 header 是什么样的? 是吗: 1|2|3|4|5|6|7|8|9|10|11|12|13|14|15|16|17|18|19|20|21|22|23|24|25|26|27|28|29|
我们的应用程序支持 CORS 配置 header 。我在两个不同的主机上分别配置了 testApp。两种设置都相互独立工作。host1 上的应用程序配置有 CORS header Access-Con
tlhelp32.h 不包含 windows.h 本身是有原因的吗?我一直在与大量的编译器错误作斗争,因为我在包含 tlhelp32.h 之后包含了 windows.h。这是设计决定还是出于什么原因?
我是一名优秀的程序员,十分优秀!