Laravel中的Blade模板引擎示例详解
前言
本文主要给大家介绍了关于laravel中blade模板引擎的相关内容,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍吧。
blade 模板引擎
blade 是 laravel 提供的一个简单强大的模板引擎,它是把 blade 视图编译成原生的 php 代码并缓存起来。缓存会在 blade 视图改变时而改变,这意味着 blade 并没有给你的应用添加编译的负担。blade 视图文件使用 .blade.php 后缀,一般都存储在 resources/views 目录下。
模板继承
先来看个例子
<!-- stored in resources/views/layouts/master.blade.php--> <html> <head> <title>app name - @yield('title')</title> </head> <body> @section('sidebar') this is the master sidebar. @show <div class="container"> @yield('content') </div> </body> </html>
blade 模板文件包含了典型的 html 标记。你肯定看到了 @section 和 @yield 指令。@section 指令就如它的名字所暗示的那样定义了一个内容区块,而 @yield 指令是用来显示所提供的挂件区块所包含的内容。我们已经定义好了一个基本的布局,接下来我们可以使用 blade 的 @extends 指令来明确的指定继承这个布局。然后使用 @section 指令将挂件中的内容挂载到布局中,在上面的例子中,挂件的内容将被挂载到布局中的 @yield 部分:
<!-- stored in resoures/views/child.blade.php --> @extends('layouts.master') @section('title', 'page title') @section('sidebar') @parent <p>this is appended to the master sidebar.</p> @endsection @section('content') <p>this is my body content.</p> @endsection
在上面的例子作用 sidebar 挂件利用 @parent 指令来追加布局中的 sidebar 部分的内容,如果不使用则会覆盖掉布局中的这部分。@parent 指令会在视图被渲染时替换为布局中的内容。
blade 视图可以像原生 php 视图一样使用全局帮助函数 view 来返回渲染后的内容:
route::get('blade', function () { return view('child'); });
显示数据
你可以使用花括号 { 来在视图中显示传递到视图中的变量,例如,你定义了下面的路由:
route::get('greeting', function () { return view('welcome', ['name' => 'duicode']); })
你可以在视图中这样来输出 name 变量的内容:
hello, {{ $name }}
当然,你也可以从原生 php 方法中返回内容。事实上,你可以在 blade echo 声明中使用任意的 php 代码:(blade {{}} 声明中的内容是自动通过 htmlentities 方法过滤的,用来防止 xss 攻击。)
the current unix timestamp is {{ time() }}
由于很多 javascript 框架都使用花括号来表明所提供的表达式应该被显示在浏览器中。所以你可以使用 @ 符号来告诉 blade 渲染引擎你需要这个表达式原样保留:
hello, @{{ name }}
我们常用三目运算符来赋值
{{ isset($name) ? $name : 'default' }}
blade 提供了一个便捷的方式来替换这个三元声明:
{{ $name or 'default' }}
默认blade {{}} 声明会自动的使用 htmlentities 方法来避免 xss 攻击。如果你不想你的数据被转义,你可以使用下面的语法,但是要注意,小心被攻击:
hello, {!! $name !!}
控制结构
你可以通过 @if,@elseif,@else和 @endif 指令来使用 if 控制结构 :
@if (count($records) === 1) i have one record! @elseif (count($records) > 1) i have multiple records! @else i don't have any records! @endif
当然为了方便,blade 也提供了替代指令 @unless 指令:
@unless (auth::check()) you are not signed in. @endunless
也可以使用 @hassection 指令来判断提供给布局的挂件是否包含了内容:
<title> @hassection('title') @yield('title') - app name @else app name @endif </title>
说到控制少不了循环结构,类似php的:
@for ($i = 0; $i < 10; $i++) the current value is {{ $i }} @endfor @foreach ($users as $user) <p>this is user {{ $user->id }}</p> @endforeach @forelse ($users as $user) <li>{{ $user->name }}</li> @empty <p>no users</p> @endforelse @while (true) <p>i'm looping forever.</p> @endwhile
blade 也提供了终止迭代或取消当前迭代的指令:
@foreach ($users as $user) @if($user->type == 1) @continue @endif <li>{{ $user->name }}</li> @if($user->number == 5) @break @endif @endforeach
你也可以使用指令声明包含条件的方式来达到中断:
@foreach ($users as $user) @continue($user->type == 1) <li>{{ $user->name }}</li> @break($user->number == 5) @endforeach
包含子视图
可以使用 @include 指令来包含一个视图的内容,当前视图中的变量也会被共享给子视图:
<div> @include('shared.errors') <form> <!-- form contents --> </form> </div>
尽管子视图会自动继承父视图中的所有数据变量,你也可以直接传递一个数组变量来添加额外的变量到子视图(在 blade 视图中避免使用 __dir__ 和 __file__ 常量,因为它们会解析为视图缓存所在的位置):
@include('view.name', ['some' => 'data'])
你可以使用 blade 的 @each 指令来在一行中合并引入多个视图:
@each('view.name', $jobs, 'job')
第一个参数是数组或集合中每个元素需要被渲染的视图名称。
第二个参数是一个数组或集合,被用来提供迭代。
第三个参数是要分配给当前视图的变量名。
你也可以传递第四个参数到 @each 指令。如果所提供的数组是空数组的话,该参数所提供的视图将会被引入。
@each('view.name', $jobs, 'job', 'view.empty')
blade 中的注释,这样写不会被渲染:
{{-- this comment will not be present in the rendered html --}}
blade 允许你在已命名的堆中压入内容:
@push('scripts') <script src="/example.js"></script> @endpush
你可以在你需要的时候压入相同的堆任意的次数,你需要在布局中使用 @stack 来渲染堆:
<head> <!-- head contents --> @stack('scripts') </head>
可以使用 @inject 指令来从服务容器中取回服务:
@inject('metrics', 'app\services\metricsservice') <div> monthly revenue: {{ $metrice->monthlyrevenue() }} </div>
第一个参数将作为所取回服务存放的变量名,
第二个参数是你想要在服务容器中取回的类或接口名称。
可以使用 directvie 方法来注册指令。当 blade 编译器遇到该指令时,它会自动的调用该指令注册时提供的回调函数并传递它的参数。
下面的例子创建了 @datetime($val) 指令来格式化 $val:
<?php namespace app\providers; use blade; use illuminate\support\serviceprovider; class appserviceprovider extends serviceprovider{ /** * perform post-registration booting of services. * * @return void */ public function boot(){ blade::directive('datetime', function ($expression) { return "<?php echo with{$express}->format('m/d/y h:i'); ?>"; }); } /** * register bindings in the container * * @return void */ public function register() { // } }
上面的例子中使用了 laravel 的 with 帮助方法,它只是简单的返回一个所提供的对象或值,并提供方便的链式调用。最终该指令生成的 php 代码如下:
<?php echo with($var)->format('m/d/y h:i'); ?>
在你更新 blade 指令的逻辑之后,你应该删除所有已缓存的 blade 视图,你可以使用 view:clear artisan 命令来清除。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
上一篇: vc6编写python扩展的方法分享
推荐阅读
-
Laravel中的Blade模板引擎示例详解
-
PHP模板引擎Smarty中变量的使用方法示例
-
Laravel模板引擎Blade中section的一些标签的区别介绍
-
详解laravel中blade模板带条件分页
-
如何通过View::first使用Laravel Blade的动态模板详解
-
Laravel框架中Blade模板的用法示例
-
Laravel模板引擎Blade中section的一些标签的区别介绍,laravelblade_PHP教程
-
Laravel模板引擎Blade中section的一些标签的区别介绍_PHP教程
-
Laravel中Blade模板的使用详解
-
laravel框架实现为 Blade 模板引擎添加新文件扩展名操作示例