[Laravel 5.3 新功能] 2. Blade 模板新增魔术变量 $loop

教程 monkey ⋅ 于 1年前 ⋅ 最后回复由 jeffyer 1年前 ⋅ 3417 阅读

说明

此文章是 [Laravel 5.3 新功能] 系列的第二篇文章,Blade 模板新增魔术变量 $loop。

[Laravel 5.3 新功能] 系列完整文章列表请见:https://laravel-china.org/topics/2638

什么是 Blade 指令

Laravel 的 Blade 模板提供了一些指令,如以 @ 符号开头的 控制结构 标签。你若写过 Blade 模板,你可能会熟悉 @if@foreach 等表达式。

这些模板指令通常都等价于 PHP 表达式。例如:@if(condition) 完全等价于 <?php if (condition):

$loop 指令介绍

在 Laravel 5.3 中,@foreach 指令提供了更加强大的功能,在每一个 @foreach 循环中都可以调用 $loop 变量。

$loop 变量是一个 stdClass 实例,包含了当前循环的元数据信息,下面是它拥有的属性:

  • index:从 1 开始计数的循环索引,1 表示第一条数据(注意不是从 0 开始!)
  • remaining:当前循环还剩余多少条数据。比如当前循环一共有 3 条数据,现在只循环了 1 条,则此时 remaining 将返回 2
  • count:循环总数
  • first:boolean 类型,值为 true 时表示当前数据为循环的第一条数据
  • last:boolean 类型,值为 true 时表示当前数据为循环的最后一条数据
  • depth:integer 类型,循环的层级。值为 2 表示当前循环中有两层循环体,其他数值以此类推
  • parent:如果循环位于另一个 @foreach 中,返回父循环 引用,否则返回 null

利用这些属性你可以编写类似以下的代码:

<ul>
@foreach ($pages as $page)
   <li>{{ $page->title }} ({{ $loop->index }} / {{ $loop->count }})</li>
@endforeach
</ul>

如果代码中有多重循环嵌套逻辑,则可通过 $loopparent 属性获取对应的数据。

<ul>
@foreach ($pages as $page)
    <li>{{ $loop->index }}: {{ $page->title }}
        @if ($page->hasChildren())
        <ul>
        @foreach ($page->children() as $child)
            <li>{{ $loop->parent->index }}.{{ $loop->index }}:
                {{ $child->title }}</li>
        @endforeach
        </ul>
        @endif
    </li>
@endforeach
</ul>

全文完。

链接

本文章首发在 Laravel China 社区
本帖已被设为精华帖!
本帖由 Summer 于 1年前 加精
回复数量: 1
您需要登陆以后才能留下评论!

Composer 中国全量镜像

Top 250 扩展包

Lumen 中文文档

Laravel 速查表

Laravel 中文文档

Laravel 项目开发规范

Laravel 开发环境部署

Composer 中文文档

Elasticsearch-PHP 中文文档

Lumen 中文文档

GraphQL PHP 中文文档

社区文档撰写指南

TDD 构建 Laravel 论坛笔记

PHP PSR 标准规范

PHP 设计模式全集

Dingo API 中文文档