我有一个相当简单的聊天记录查看器,它使用Laravel分页器轻松地将返回的日志分成页面。不幸的是,paginator只返回结果的第一页,即使它正确地呈现了页数。
这是控制器代码:
public function search(Requests\ChatSearchRequest $request)
{
//split search up into what we've got
$request->flash();
$nick = $request->input('nick');
$message = $request->input('message');
$channel = $request->input('channel');
$time_start = $request->input('datestart');
$time_end = $request->input('dateend');
$sortby = $request->input('sortby');
$limit = (int) $request->input('limit');
$page = (int) $request->input('page');
$query = ChatMessage::query();
if (!empty($nick))
$query->usersLike($nick);
if (!empty($channel))
$query->fromChannel($channel);
if (!empty($message))
$query->matchMessage($message);
if (!empty($time_start))
$query->betweenTimes($time_start, $time_end);
$query->orderBy('id', $sortby);
$messageResults = $query->take($limit)->get();
$messages = new LengthAwarePaginator($messageResults->all(), $messageResults->count(), 100, $page, ['path' => Paginator::resolveCurrentPath(), 'query' => $request->query()]);
return view('chatlog', compact('messages'));
}
以下是页面使用的表单生成的请求:
http://localhost/chatlog/search?message=&nick=Saten&channel=&datestart=2017-09-17T14%3A50%3A44&dateend=2017-09-24T14%3A50%3A44&limit=250&sortby=desc&page=3
我从其他问题中尝试了很多东西,但这里无济于事。我尝试使用Paginator::resolveCurrentPage()
代替直接从请求中提取页面,但没有成功。似乎没有什么能使它发挥作用。
奇怪的是,使用simplePaginate的同一个控制器上的索引视图工作正常。该表单是使用Laravel Collective表单构建的,是否可以省略csrf_token并在请求端使请求退回?
答案 0 :(得分:1)
对于使用此查询的所有网页,您始终会获得前250条记录:
$query->take($limit)->get()
所以请尝试添加这样的偏移量:
$query->skip($limit*$page)->take($limit)->get()
它应该跳过以前页面的记录,您将只获得当前页面的记录。
您还将错误的数据传递给LengthAwarePaginator
构造函数。试试这个:
$messages = new LengthAwarePaginator(
$messageResults->all(),
ChatMessage::count(),//total count
$limit,//items per page
$page,//current page
['path' => Paginator::resolveCurrentPath(), 'query' => $request->query()]
);