Templating

Contents

The Basics

Your application probably uses a common layout across most of its pages. Manually creating this layout within every controller action can be a pain. Specifying a controller layout will make your development much more enjoyable. Here's how to get started:

Specify a "layout" property on your controller:

class Base_Controller extends Controller {

    public $layout = 'layouts.common';

}

Access the layout from the controllers' action:

public function action_profile()
{
    $this->layout->nest('content', 'user.profile');
}

Note: When using layouts, actions do not need to return anything.

Sections

View sections provide a simple way to inject content into layouts from nested views. For example, perhaps you want to inject a nested view's needed JavaScript into the header of your layout. Let's dig in:

Creating a section within a view:

<?php Section::start('scripts'); ?>
    <script src="jquery.js"></script>
<?php Section::stop(); ?>

Rendering the contents of a section:

<head>
    <?php echo Section::_yield('scripts'); ?>
</head>

Using Blade short-cuts to work with sections:

@section('scripts')
    <script src="jquery.js"></script>
@endsection

<head>
    @yield('scripts')
</head>

Blade Template Engine

Blade makes writing your views pure bliss. To create a blade view, simply name your view file with a ".blade.php" extension. Blade allows you to use beautiful, unobtrusive syntax for writing PHP control structures and echoing data. Here's an example:

Echoing a variable using Blade:

Hello, {{ $name }}.

Echoing function results using Blade:

{{ Asset::styles() }}

Render a view:

You can use @include to render a view into another view. The rendered view will automatically inherit all of the data from the current view.

<h1>Profile</hi>
@include('user.profile')

Similarly, you can use @render, which behaves the same as @include except the rendered view will not inherit the data from the current view.

@render('admin.list')

Blade comments:

{{-- This is a comment --}}

{{--
    This is a
    multi-line
    comment.
--}}

Note: Unlike HTML comments, Blade comments are not visible in the HTML source.

Blade Control Structures

For Loop:

@for ($i = 0; $i <= count($comments); $i++)
    The comment body is {{ $comments[$i] }}
@endfor

Foreach Loop:

@foreach ($comments as $comment)
    The comment body is {{ $comment->body }}.
@endforeach

While Loop:

@while ($something)
    I am still looping!
@endwhile

If Statement:

@if ( $message == true )
    I'm displaying the message!
@endif

If Else Statement:

@if (count($comments) > 0)
    I have comments!
@else
    I have no comments!
@endif

Else If Statement:

@if ( $message == 'success' )
    It was a success!
@elseif ( $message == 'error' )
    An error occurred.
@else
    Did it work?
@endif

For Else Statement:

@forelse ($posts as $post)
    {{ $post->body }}
@empty
    There are not posts in the array!
@endforelse

Unless Statement:

@unless(Auth::check())
    Login
@endunless

// Equivalent to…

<?php if ( ! Auth::check()): ?>
    Login
<?php endif; ?>

Blade Layouts

Not only does Blade provide clean, elegant syntax for common PHP control structures, it also gives you a beautiful method of using layouts for your views. For example, perhaps your application uses a "master" view to provide a common look and feel for your application. It may look something like this:

<html>
    <ul class="navigation">
        @section('navigation')
            <li>Example Item 1</li>
            <li>Example Item 2</li>
        @endsection
    </ul>

    <div class="content">
        @yield('content')
    </div>
</html>

Notice the "content" section being yielded. We need to fill this section with some text, so let's make another view that uses this layout:

@layout('master')

@section('content')
    Welcome to the profile page!
@endsection

Great! Now, we can simply return the "profile" view from our route:

return View::make('profile');

The profile view will automatically use the "master" template thanks to Blade's @layout expression.

Important: The @layout call must always be on the very first line of the file, with no leading whitespaces or newline breaks.

Appending with @parent

Sometimes you may want to only append to a section of a layout rather than overwrite it. For example, consider the navigation list in our "master" layout. Let's assume we just want to append a new list item. Here's how to do it:

@layout('master')

@section('navigation')
    @parent
    <li>Nav Item 3</li>
@endsection

@section('content')
    Welcome to the profile page!
@endsection

@parent will be replaced with the contents of the layout's navigation section, providing you with a beautiful and powerful method of performing layout extension and inheritance.