搜索查询在laravel中失去了分页

时间:2016-07-25 02:50:42

标签: php mysql laravel pagination

我对laravel和后端的东西很新,所以这可能是一个新问题!

我的网站有一个搜索引擎,用于查找用户。

现在我使用一个非常简单的搜索控制器,下面是代码。

class SearchController extends Controller {
public function getResults(Request $request) {
    $query = $request->input('query');

    if (!$query) {
        return redirect()->route('home');
    }

    $users = User::where(DB::raw("CONCAT(first_name, ' ', last_name)"), 'LIKE', "%{$query}%")->where('role', '=', 2)
    ->orWhere('username', 'LIKE', "%{$query}%")->where('role', '=', 2)
    ->orWhere('profile_text', 'LIKE', "%{$query}%")->where('role', '=', 2)
    ->orWhere('keywords', 'LIKE', "%{$query}%")->where('role', '=', 2)
    ->simplePaginate(1);




    return view('search.results')->with('users', $users);
 }
}

结果页面:

@extends('templates.default')

 @section('content')
    <h3>Results for "{{ Request::input('query') }}"</h3>


    @if (!$users->count())
        <p>No results found, sorry.</p>
    @else

    <div class="resultRow">
        <div class="">
            @foreach ($users as $user)
                     {{ $user->username }}
            @endforeach

        {!! $users->render() !!}
        </div>
    </div>
    @endif
@stop

因此,如果我要搜索&#34; John&#34;,我会得到所有Johns的结果,其中网址为http://localhost/search?query=John

但是,如果我点击结果的下一页(http://localhost/search?page=2),查询就会丢失,所以我的搜索控制器只会将我发回我的主页。

如何通过分页保持查询?

编辑:我很确定我的问题是它在点击第2页后再次通过搜索控制器,但我不知道如何解决这个问题。

3 个答案:

答案 0 :(得分:3)

getResult函数中,将$query变量传递给视图

return view('search.results', ['users' => $users, 'query' => $query]);

然后在您的视图中,附加您需要的查询或其他变量

{{ $users->appends(['query' => $query])->links() }}

您可以在laravel docs

中查看更多内容

答案 1 :(得分:2)

切换

{!! $users->render() !!} 

{!! $users->appends(Request::except('page'))->render() !!}

像魅力一样工作。归功于:Laravel 5 route pagination url encoding issue(不相关的问题)

答案 2 :(得分:0)

您可以通过以下方式使用分页。

$users->withQueryString()->links()