我有一个项目,我要从数据库中提取帖子并在主页视图上进行渲染。就像博客一样。 (在主页上,我限制为3个帖子)
我在表中有6行,并希望根据ODD和偶数行设置输出样式。
这是我的控制人:
SELECT AppUserName, UserFirstName, UserLastName
FROM ApplicationUsers
WHERE @AppUserName = AppUserName
我希望偶数行具有public function index()
{
$counter = Post::count();
$posts= DB::table('posts')->orderBy('id', 'DESC')->limit(3)->get();
return view('home',compact('posts','counter'));
}
,奇数行具有<div class="even">
当我在<div class="odd">
上dd
时,得到的值为6。这是正确的。表中有6行。
根据我发现的其他文章,我目前正在尝试的内容:
$counter
这什么也没做。仍将行输出为6,5,4,3,2,1
那么我该如何在我的Foreach循环中编写IF语句来表示...
@foreach ($posts as $post)
@if($counter % 2 == 0)
<div class="even">{{$post->title}}</div>
@else
<div class="odd">{{$post->title}}</div>
@endif
我要寻找的顺序是:
答案 0 :(得分:6)
$counter
是静态变量,因此调用$counter % 2 == 0
将始终显示相同的结果。如果您使用的是5.4+,则$loop
中包含一个@foreach()
变量。这样您就可以在循环中访问您的mod部门。
@foreach ($posts as $post)
@if($loop->iteration % 2 == 0)
<div class="even">{{$post->title}}</div>
@else
<div class="odd">{{$post->title}}</div>
@endif
答案 1 :(得分:4)
答案 2 :(得分:1)
您需要在每次迭代时增加计数器。
@php
$counter = 1;
@endphp
@foreach ($posts as $post)
@if($counter % 2 == 0)
<div class="even">{{$post->title}}</div>
@else
<div class="odd">{{$post->title}}</div>
@endif
@php
$counter++;
@endphp
@endforeach