在Laravel中分页时搜索查询丢失。

5

我对 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”,我将得到所有约翰的结果,URL为http://localhost/search?query=John
然而,如果我点击结果的下一页(http://localhost/search?page=2),查询就会丢失,因此我的搜索控制器会将我带回主页。
如何在分页中保留查询?
编辑:我非常确定我的问题是在点击第二页后再次经过搜索控制器,但我不知道该如何解决这个问题。
3个回答

6

1
对我来说需要一点编辑,但它确实像魔法一样运行{{ $companies->appends(Request::all())->links() }}。谢谢! - Darius

4
在你的getResult函数中,将一个$query变量传递给视图。
return view('search.results', ['users' => $users, 'query' => $query]);

然后在您的视图中,附加您需要的查询或其他变量。
{{ $users->appends(['query' => $query])->links() }}

you can check more in laravel docs


1
您可以这样使用分页。
$users->withQueryString()->links() 

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接