Laravel中的Blade模板引擎示例详解
前言
本文主要给大家介绍了关于Laravel中Blade模板引擎的相关内容,分享出来供大家参考学习,话不多说了,来一起看看详细的介绍吧。
Blade模板引擎
Blade是laravel提供的一个简单强大的模板引擎,它是把Blade视图编译成原生的PHP代码并缓存起来。缓存会在Blade视图改变时而改变,这意味着Blade并没有给你的应用添加编译的负担。Blade视图文件使用.blade.php后缀,一般都存储在resources/views目录下。
模板继承
先来看个例子
AppName-@yield('title') @section('sidebar') Thisisthemastersidebar. @show@yield('content')
Blade模板文件包含了典型的HTML标记。你肯定看到了@section和@yield指令。@section指令就如它的名字所暗示的那样定义了一个内容区块,而@yield指令是用来显示所提供的挂件区块所包含的内容。我们已经定义好了一个基本的布局,接下来我们可以使用Blade的@extends指令来明确的指定继承这个布局。然后使用@section指令将挂件中的内容挂载到布局中,在上面的例子中,挂件的内容将被挂载到布局中的@yield部分:
@extends('layouts.master') @section('title','PageTitle') @section('sidebar') @parentThisisappendedtothemastersidebar.
@endsection @section('content')Thisismybodycontent.
@endsection
在上面的例子作用sidebar挂件利用@parent指令来追加布局中的sidebar部分的内容,如果不使用则会覆盖掉布局中的这部分。@parent指令会在视图被渲染时替换为布局中的内容。
Blade视图可以像原生PHP视图一样使用全局帮助函数view来返回渲染后的内容:
Route::get('blade',function(){ returnview('child'); });
显示数据
你可以使用花括号{来在视图中显示传递到视图中的变量,例如,你定义了下面的路由:
Route::get('greeting',function(){ returnview('welcome',['name'=>'Duicode']); })
你可以在视图中这样来输出name变量的内容:
Hello,{{$name}}
当然,你也可以从原生PHP方法中返回内容。事实上,你可以在Bladeecho声明中使用任意的PHP代码:(Blade{{}}声明中的内容是自动通过htmlentities方法过滤的,用来防止XSS攻击。)
ThecurrentUNIXtimestampis{{time()}}
由于很多JavaScript框架都使用花括号来表明所提供的表达式应该被显示在浏览器中。所以你可以使用@符号来告诉Blade渲染引擎你需要这个表达式原样保留:
Hello,@{{name}}
我们常用三目运算符来赋值
{{isset($name)?$name:'Default'}}
Blade提供了一个便捷的方式来替换这个三元声明:
{{$nameor'Default'}}
默认Blade{{}}声明会自动的使用htmlentities方法来避免XSS攻击。如果你不想你的数据被转义,你可以使用下面的语法,但是要注意,小心被攻击:
Hello,{!!$name!!}
控制结构
你可以通过@if,@elseif,@else和@endif指令来使用if控制结构:
@if(count($records)===1) Ihaveonerecord! @elseif(count($records)>1) Ihavemultiplerecords! @else Idon'thaveanyrecords! @endif
当然为了方便,Blade也提供了替代指令@unless指令:
@unless(Auth::check()) Youarenotsignedin. @endunless
也可以使用@hasSection指令来判断提供给布局的挂件是否包含了内容:
@hasSection('title') @yield('title')-AppName @else AppName @endif
说到控制少不了循环结构,类似PHP的:
@for($i=0;$i<10;$i++) Thecurrentvalueis{{$i}} @endfor @foreach($usersas$user)Thisisuser{{$user->id}}
@endforeach @forelse($usersas$user)
Nousers
@endforelse @while(true)I'mloopingforever.
@endwhileBlade也提供了终止迭代或取消当前迭代的指令:
@foreach($usersas$user) @if($user->type==1) @continue @endif
你也可以使用指令声明包含条件的方式来达到中断:
@foreach($usersas$user) @continue($user->type==1)
包含子视图
可以使用@include指令来包含一个视图的内容,当前视图中的变量也会被共享给子视图:
@include('shared.errors')
尽管子视图会自动继承父视图中的所有数据变量,你也可以直接传递一个数组变量来添加额外的变量到子视图(在Blade视图中避免使用__DIR__和__FILE__常量,因为它们会解析为视图缓存所在的位置):
@include('view.name',['some'=>'data'])
你可以使用Blade的@each指令来在一行中合并引入多个视图:
@each('view.name',$jobs,'job')
第一个参数是数组或集合中每个元素需要被渲染的视图名称。
第二个参数是一个数组或集合,被用来提供迭代。
第三个参数是要分配给当前视图的变量名。
你也可以传递第四个参数到@each指令。如果所提供的数组是空数组的话,该参数所提供的视图将会被引入。
@each('view.name',$jobs,'job','view.empty')
Blade中的注释,这样写不会被渲染:
{{--ThiscommentwillnotbepresentintherenderedHTML--}}
Blade允许你在已命名的堆中压入内容:
@push('scripts')@endpush
你可以在你需要的时候压入相同的堆任意的次数,你需要在布局中使用@stack来渲染堆:
@stack('scripts')
可以使用@inject指令来从服务容器中取回服务:
@inject('metrics','App\Services\MetricsService')MonthlyRevenue:{{$metrice->monthlyRevenue()}}
第一个参数将作为所取回服务存放的变量名,
第二个参数是你想要在服务容器中取回的类或接口名称。
可以使用directvie方法来注册指令。当Blade编译器遇到该指令时,它会自动的调用该指令注册时提供的回调函数并传递它的参数。
下面的例子创建了@datetime($val)指令来格式化$val:
format('m/d/YH:i');?>"; }); } /** *Registerbindingsinthecontainer * *@returnvoid */ publicfunctionregister(){ // } }
上面的例子中使用了Laravel的with帮助方法,它只是简单的返回一个所提供的对象或值,并提供方便的链式调用。最终该指令生成的PHP代码如下:
format('m/d/YH:i');?>
在你更新Blade指令的逻辑之后,你应该删除所有已缓存的Blade视图,你可以使用view:clearArtisan命令来清除。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对毛票票的支持。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。