【问题标题】:Search query lost on pagination in laravel搜索查询在 laravel 中的分页丢失
【发布时间】:2016-11-28 06:44:06
【问题描述】:

我对 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

所以如果我要搜索“John”,我会得到所有 Johns 的结果,URL 是 http://localhost/search?query=John

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

如何通过分页保持查询?

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

【问题讨论】:

    标签: php mysql laravel pagination


    【解决方案1】:

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

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

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

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

    您可以在laravel docs查看更多信息

    【讨论】:

      【解决方案2】:

      切换

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

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

      像魅力一样工作。致谢:Laravel 5 route pagination url encoding issue(无关问题)

      【讨论】:

      • 对我来说需要位编辑,但它确实像魅力 {{ $companies->appends(Request::all())->links() }} 谢谢!
      【解决方案3】:

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

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

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2017-12-28
        • 2014-06-29
        • 1970-01-01
        • 2012-06-18
        相关资源
        最近更新 更多