Php 搜索查询在laravel中分页时丢失

Php 搜索查询在laravel中分页时丢失,php,mysql,laravel,pagination,Php,Mysql,Laravel,Pagination,我对laravel和后端的东西都很陌生,所以这可能是个新问题 我的网站有一个用来查找用户的搜索引擎 现在我正在使用一个非常简单的搜索控制器,下面是代码 class SearchController extends Controller { public function getResults(Request $request) { $query = $request->input('query'); if (!$query) { return redire

我对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
@extends('templates.default')
@节(“内容”)
“{Request::input('query')}”的结果
@如果(!$users->count())
没有找到结果,抱歉

@否则 @foreach($users作为$user) {{$user->username} @endforeach {!!$users->render()!!} @恩迪夫 @停止
因此,如果我搜索“John”,我会得到所有John的结果,URL为

但是,如果我单击results()的下一页,查询将丢失,因此我的搜索控制器只会将我发送回主页

如何通过分页保持查询


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

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

return view('search.results', ['users' => $users, 'query' => $query]);
然后在视图中,附加所需的查询或其他变量

{{ $users->appends(['query' => $query])->links() }}
您可以在中查看更多信息

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


工作起来很有魅力。归功于:(无关问题)

您可以按以下方式使用分页

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

对我来说,需要一点编辑,但它真的像charm{{$companys->appends(Request::all())->links()}谢谢!虽然此链接可以回答问题,但最好在此处包含答案的基本部分,并提供链接供参考。如果链接页面发生更改,则仅链接的答案可能无效-
$users->withQueryString()->links()