Laravel Blade Foreach 只显示 10 个项目

问题描述

这将从数据库中加载 12 名候选人。

()

$candidates = Candidate::all()->where('vacancy_id',$id); 返回 count($candidates)

但是在我的 foreach 循环中。比如

12

然而 $sum = 0; @foreach($candidates as $candidate) $sum +=1; @endforeach 返回 $sum 而不是 10

有什么想法吗?

Laravel 8 PHP 8

解决方法

如果您尝试打印 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();