Fel*_*ime 4 php mysql pagination laravel
我对 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);
}
}
Run Code Online (Sandbox Code Playgroud)
结果页面:
@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
Run Code Online (Sandbox Code Playgroud)
所以如果我要搜索“John”,我会得到所有 John 的结果,URL 是http://localhost/search?query=John。
但是,如果我单击下一页结果 ( http://localhost/search?page=2 ),查询就会丢失,因此我的搜索控制器只会将我送回我的主页。
如何通过分页保留查询?
编辑:我很确定我的问题是它在点击第 2 页后再次通过搜索控制器,但我不知道如何解决这个问题。
切换
{!! $users->render() !!}
Run Code Online (Sandbox Code Playgroud)
和
{!! $users->appends(Request::except('page'))->render() !!}
Run Code Online (Sandbox Code Playgroud)
奇迹般有效。归功于:Laravel 5 路由分页 url 编码问题(无关问题)
归档时间: |
|
查看次数: |
3155 次 |
最近记录: |