我的分页正确处理第一页。它正确显示2个名称。当我想在接下来的页面上看到其他结果时,它将不显示任何与我当前的代码。当我制作一个静态数组时:搜索结果分页laravel
$searchResults = [
'item1',
'item2',
'item3',
'item4',
'item5',
];
它会在不同的页面上正确显示数组。 当我从我的sql查询中创建一个数组时,它在接下来的页面上什么也不显示。 我使用var_dump,并在第二页上,我没有看到我创建的数组的任何东西。
这是我的控制器代码:
public function zoekdocument(Request $request) //voor het zoeken van software
{
$zoekdocument = \Request::get('zoekdocument');
$searchResult = array();
$searchdoc = \DB::table('visits')->where('title', 'LIKE', '%' . $zoekdocument . '%')->paginate();
foreach($searchdoc as $searchdocument){
$filedir = $searchdocument->pagename; //wordt gedurende loop tot die finisht in de array gezet.
$searchResult[] = $filedir; //dat wordt hier gedaan.
}
$currentPage = LengthAwarePaginator::resolveCurrentPage();
$page = $request->has('page') ? $request->get('page') : 1;
//Create a new Laravel collection from the array data
$collection = new Collection($searchResult);
$perPage = 2;
$currentPageSearchResults = $collection-> slice (($currentPage -1) * $perPage, $perPage)->all();
//Create our paginator and pass it to the view
$paginatedSearchResults= new
LengthAwarePaginator($currentPageSearchResults, count($collection), $perPage, $page, ['path' => $request->url(),'query' => $request->query(),
return view('Documentatie.result', ['results' => $paginatedSearchResults])->with('zoekdocument', $zoekdocument);
这是我的看法代码:
@section('content')
<!-- Striped rows -->
<div class="panel panel-flat">
<div class="panel-heading">
<h5 class="panel-title text-center">Documentatie overzicht resultaat</h5>
<div class="heading-elements">
</div>
</div>
<div class="text-center">
<h2>Zoekresultaat van: <b><i>{{$zoekdocument}}</b></i></h5>
</div>
@foreach ($results as $result)
<p>{{ $result }}</p>
@endforeach
<?php echo $results->render(); ?>
@endsection
它不起作用。它的奇怪,当我做一个静态数组时,它的工作原理。我认为这是我的SQL查询出错。我的查询检查与搜索到的单词是否一致,并创建一个数组。例如:keyword =“te”,并且查询在数据库中搜索带有“te”的名称。之后,它将通过循环将其放入数组中。当我点击下一页时,数组是空的。 – jurh