Php 搜索查询在laravel中分页时丢失
我对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
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()