如何刷新分页3库中的页码

如何解决如何刷新分页3库中的页码

我正在使用分页3在回收器视图中加载一些数据。我从服务器获取数据,然后将其存储在本地数据库中。 这是我的DAO界面:

@Dao
interface TicketDAO {


    @Insert(onConflict = OnConflictStrategy.REPLACE)
    fun insert(model: TicketListModel)


    @Query("SELECT * FROM ticket_list ORDER BY lastModifyDate DESC,lastModifyTime DESC")
    fun getTickets(): PagingSource<Int,TicketListModel>


    @Query("delete from ticket_list")
    fun deleteall()


}

我假定此接口为我的数据源类。由于我也从服务器获取数据,因此我使用了这样的远程中介器(顺便说一下,我使用凌空协议从服务器获取数据):


@ExperimentalPagingApi
class TicketRemoteMediator(val ticketDatabase: TicketDAO,val context: Context) :
    RemoteMediator<Int,TicketListModel>() {

    private val scope = Coroutinescope(dispatchers.Default)
    private var page = 0
    private var reachedEnd = false
    override suspend fun load(
        loadType: LoadType,state: PagingState<Int,TicketListModel>
    ): MediatorResult {
        return try {
            fetchData(page = page)
            page += 1
            Log.i("Log","page is $page")
            MediatorResult.Success(endOfPaginationReached = reachedEnd)
        } catch (e: Exception) {
            page -= 1
            MediatorResult.Error(e)
        }

    }

    private fun fetchData(page: Int) {
        val request = object : JsonObjectRequest(
            Method.GET,Address().getTicketAPI(page),null,Response.Listener {
                reachedEnd = true
                val info = it.getJSONArray("results")
                for (i in 0 until info.length()) {
                    val data = info.getJSONObject(i)
                    scope.launch {
                        async(dispatchers.Default,Coroutinestart.DEFAULT,block = {
                            ticketDatabase.insert(
                                TicketListModel(
                                    subject = data.getString("subject"),status = data.getString("status"),)
                            reachedEnd = false
                        }).await()
                    }
                }

            },Response.ErrorListener {
                this.page -= 1
                reachedEnd = false
                try {
                    Log.i("Log","error in ticket remoteMediator ${String(it.networkResponse.data,Charsets.UTF_8)}")
                }catch (e:Exception){
                    Log.i("Log","error in ticket mediator $it")
                }

            }
        ) {
            @Throws(AuthFailureError::class)
            override fun getHeaders(): MutableMap<String,String> {
                val token = HashMap<String,String>()
                token["Authorization"] =
                    "Bearer ${Config().accesstoken}"
                return token
            }
        }
        request.retryPolicy = DefaultRetryPolicy(10000,5,DefaultRetryPolicy.DEFAULT_BACKOFF_MULT)
        val queue = Volley.newRequestQueue(context)
        queue.add(request)
    }
}

并使用我的视图模型类使用数据,如下所示:

    val isLoading = mutablelivedata<Boolean>()

    @ExperimentalPagingApi
    val tickets= Pager(
        config = PagingConfig(pageSize =5),remoteMediator = TicketRemoteMediator(ticketDatabase = database,context = context)
    ) {
        database.getTickets()

    }.liveData.cachedIn(viewmodelScope).also {
        isLoading.value = false
    }

并且我的片段中有这段代码

            viewmodel.tickets.observe(viewLifecycleOwner,Observer {
                viewLifecycleOwner.lifecycleScope.launch {
                    adapter.submitData(it)
                }
            })

回收站视图适配器的哪个部分是:


class Ticketlistadapter :  PagingDataAdapter<TicketListModel,Ticketlistadapter.ViewHolder>(
   diffCallback =      object : DiffUtil.ItemCallback<TicketListModel>() {
       override fun areItemsTheSame(oldItem: TicketListModel,newItem: TicketListModel): Boolean {
           return oldItem.ticket_id == newItem.ticket_id
       }
       override fun areContentsTheSame(
           oldItem: TicketListModel,newItem: TicketListModel
       ): Boolean {
           return oldItem == newItem
       }

   }
) {

...
}

现在,我有两个问题:

首先: 我的用户有时想刷新列表。使用滑动刷新。 因此,我为此设置了以下代码行,但没有任何反应:

        binding.refresh.setonRefreshListener {
            database.getTickets().invalidate()
        }

第二: 即使用户尚未滚动,来自服务器的大量分页库请求也很多。实际上,当我登录时,我看到有20多个请求发送到服务器,而在1或2个请求之后,所有信息都可以从服务器中获取

我该如何解决这些问题?

解决方法

刷新很容易,您只需要在适配器上调用refresh()

binding.refresh.setOnRefreshListener{
    pagingAdapter.refresh()
}

至于有多个请求,这可能取决于您对pageSize给予的PagingConfig。如果您查看其中的其他参数,您会发现initialLoadSize的默认值是pageSize的三倍。这意味着它将在满意之前尝试加载pageSize * 3个项目。 Address().getTicketAPI(page)

返回了多少项目

更新

我刚刚注意到,您的load方法始终假定我们在实际调用下一页时也尝试加载下一页,以刷新和加载上一页。 loadType参数决定了我们要加载的方向。

以下是您的加载方法应为什么样的示例

val nextPage = when (loadType) {
    LoadType.REFRESH -> 0 // we're refreshing so just reset the page
    LoadType.PREPEND -> return MediatorResult.Success(endOfPaginationReached = true) // shouldn't need to prepend
    LoadType.APPEND -> {
        // work out the next page number
        page + 1
    }

return try {
     fetchData(page = nextPage)
     Log.i("Log","page is $nextPage")
     MediatorResult.Success(endOfPaginationReached = reachedEnd)
} catch (e: Exception) {
     MediatorResult.Error(e)
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?