问题描述
这将从数据库中加载 12 名候选人。
()
做 $candidates = Candidate::all()->where('vacancy_id',$id);
返回 count($candidates)
但是在我的 foreach 循环中。比如
12
然而 $sum = 0;
@foreach($candidates as $candidate)
$sum +=1;
@endforeach
返回 $sum
而不是 10
。
有什么想法吗?
解决方法
如果您尝试打印 10 而不是 12 的原因是为了可以分页,您应该使用 Laravel 的分页器:
$candidates = Candidate::all()->where('vacancy_id',$id)->paginate(10);
试试这个:
@foreach($candidates as $key => $candidate)
@if($key < 10)
{{$candidate->value}}
@endif
@endforeach
,
你的循环有问题,如果你使用all()
就不需要使用where
条件,where条件使用get()
$candidates = Candidate::where('vacancy_id',$id)->get();
你的循环
@foreach($candidates AS $candidate_key => $candidate_value)
@if($candidate_key <= 9)
{{ $candidate_value->vacancy_id }}
@endif
@endforeach
,
为什么不直接做?
@foreach($candidates as $team)
{{$loop->iteration}}
@endforeach
$loop->iteration:当前循环迭代(从 1 开始)。
此处有更多信息:https://laravel.com/docs/8.x/blade。
,试试这个
$candidates = Candidate::where('vacancy_id',$id)->get();