分页不考虑结果的变化

Posted

技术标签:

【中文标题】分页不考虑结果的变化【英文标题】:Paginate does not account for changing results 【发布时间】:2019-11-17 00:14:46 【问题描述】:

我在 Laravel 中使用 paginate 来加载大量数据。快速变化的数据。问题是当用户滚动数据时,新行被插入到顶部。这会产生一个问题,即在用户加载第 1 页和第 2 页之间的时间内,用户看到从第 1 页推到第 2 页的重复行。例如:

数据:

    D E F

用户 A 使用 ->simplePaginate(2) 加载结果。

第 1 页加载:

结果:

    D E

在数据库中插入一行。

数据:

    C D E F

现在,用户 A 在页面 #1 上滚动浏览他的结果并加载页面 #2:

结果:

    E F

用户 A 现在刚刚看到:

    D E E F

在加载第二页时,我有什么方法可以轻松解决这个问题?

用户 A 应该看过

    D E F

当用户 A 加载页面 #2 说“嘿,现在顶部有新结果”时传递一些信息也非常酷。

【问题讨论】:

【参考方案1】:

在第 1 页获取时间戳,然后在查询中添加一个附加子句,断言 created_at 在时间戳之前。

$beforeTime = $request->input('before_time', Carbon::now());
$items = Item::where('created_at', '<=', $beforeTime)->paginate(2);

最后,确保将before_time 参数附加到分页链接:

echo $items->appends(['before_time' => $beforeTime])->links();

【讨论】:

这太完美了!

以上是关于分页不考虑结果的变化的主要内容,如果未能解决你的问题,请参考以下文章

Laravel 方法分页不存在

PHP+MYSQL查询结果上加一个排名序号且分页不间断

ng+ant分页不显示问题

thinkPHP5开发智慧软文遇到的分页第二页不显示数据的问题

kaminari ajax 分页不更新分页

Codeigniter 分页不呈现分页链接