来自 AJAX 请求的分页无法正常工作 -- Laravel 5.6
Pagination coming from AJAX request not working properly -- Laravel 5.6
我正在使用 Laravel 5.6 -- Jquery Ajax
重点是
我在我的导航栏中放置了一个搜索输入,上面有一个事件监听器('keyup')。
每次触发 keyup 时,都会向
发送一个 AJAX GET 请求
url : '{{action('PostController@searchAdmin')}}'
来自 web.php : Route::get('/search/admin', 'PostController@searchAdmin')
;
我将那个动作的 return 设为部分数据
return view('back.partials.searchResult', ['posts' => $posts, 'trashed' => $trashed]);
然后我用那个部分
替换主标签的内容
除结果计数大于 10(分页断点)外,一切正常。
分页控制链接都指向 "search/admin?page=x",当我点击它时,显示此错误
Undefined variable: posts
我用$posts->links()
来显示控件
我找到了解决方案,所以我 post 它
在web.php
Route::get('/search', function(Request $request) {
$search = $request->search;
$trashed = Post::trash()->count();
$posts = Post::notTrash()
->where('title', 'like', '%' . $search . "%")
->orWhere('post_type' , 'like', '%' . $search . '%')
->paginate(10);
$posts->withPath('?search=' . $search);
return view('back.partials.searchResult', ['posts' => $posts, 'trashed' => $trashed, 'search' => $search]);
});
此代码用于测试目的,将很快导出到名为 SearchController
的新控制器中
在我的 PostController 中
public function index(Request $request)
{
// GET parameters
$paginate = $request->input('paginate') ?? 10;
$search = $request->input('search') ?? null;
if($search !== null) {
$posts = $this->checkCategories($paginate, $search);
} else {
$posts = Post::notTrash()->orderBy('id', 'ASC')->paginate($paginate);
}
$trashed = Post::trash()->count();
$posts->withPath('?search=' . $search);
return view('back.index', ['posts' => $posts, 'trashed' => $trashed, 'search' => $search]);
}
与
合作
private function checkCategories($paginate, $search)
{
$categories = Category::all();
foreach ($categories as $category) {
if(strpos(strtolower($category->name), $search) === false) {
// @TODO: Change for stripos
$posts = Post::notTrash()
->where('title', 'like', '%' . $search . '%')
->orWhere('post_type', 'like', '%' . $search . '%')
->paginate($paginate);
} else {
return Category::find($category->id)->posts()->paginate($paginate);
}
}
return $posts;
}
index 方法现在接受 Request 来处理 get 参数。
在我看来
@if($search !== null)
{{ $posts->appends($search)->links() }}
@else
{{ $posts->links() }}
@endif
现在替换
{{ $posts->links() }}
解决方案是 $var->**withPath()**
并处理 GET 参数
我正在使用 Laravel 5.6 -- Jquery Ajax
重点是
我在我的导航栏中放置了一个搜索输入,上面有一个事件监听器('keyup')。
每次触发 keyup 时,都会向
发送一个 AJAX GET 请求url : '{{action('PostController@searchAdmin')}}'
来自 web.php : Route::get('/search/admin', 'PostController@searchAdmin')
;
我将那个动作的 return 设为部分数据
return view('back.partials.searchResult', ['posts' => $posts, 'trashed' => $trashed]);
然后我用那个部分
替换主标签的内容除结果计数大于 10(分页断点)外,一切正常。
分页控制链接都指向 "search/admin?page=x",当我点击它时,显示此错误
Undefined variable: posts
我用$posts->links()
来显示控件
我找到了解决方案,所以我 post 它
在web.php
Route::get('/search', function(Request $request) {
$search = $request->search;
$trashed = Post::trash()->count();
$posts = Post::notTrash()
->where('title', 'like', '%' . $search . "%")
->orWhere('post_type' , 'like', '%' . $search . '%')
->paginate(10);
$posts->withPath('?search=' . $search);
return view('back.partials.searchResult', ['posts' => $posts, 'trashed' => $trashed, 'search' => $search]);
});
此代码用于测试目的,将很快导出到名为 SearchController
的新控制器中在我的 PostController 中
public function index(Request $request)
{
// GET parameters
$paginate = $request->input('paginate') ?? 10;
$search = $request->input('search') ?? null;
if($search !== null) {
$posts = $this->checkCategories($paginate, $search);
} else {
$posts = Post::notTrash()->orderBy('id', 'ASC')->paginate($paginate);
}
$trashed = Post::trash()->count();
$posts->withPath('?search=' . $search);
return view('back.index', ['posts' => $posts, 'trashed' => $trashed, 'search' => $search]);
}
与
合作private function checkCategories($paginate, $search)
{
$categories = Category::all();
foreach ($categories as $category) {
if(strpos(strtolower($category->name), $search) === false) {
// @TODO: Change for stripos
$posts = Post::notTrash()
->where('title', 'like', '%' . $search . '%')
->orWhere('post_type', 'like', '%' . $search . '%')
->paginate($paginate);
} else {
return Category::find($category->id)->posts()->paginate($paginate);
}
}
return $posts;
}
index 方法现在接受 Request 来处理 get 参数。
在我看来
@if($search !== null)
{{ $posts->appends($search)->links() }}
@else
{{ $posts->links() }}
@endif
现在替换
{{ $posts->links() }}
解决方案是 $var->**withPath()**
并处理 GET 参数