Laravel 5 Paginator仅返回第一页

时间:2017-09-24 15:00:49

标签: php laravel-5 pagination

我有一个相当简单的聊天记录查看器,它使用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并在请求端使请求退回?

1 个答案:

答案 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()]
    );