一、简介模板引擎
模板引擎是将网站的页面设计和PHP应用程序几乎完全分离的一种解决方案,它能让前端工程师专注页面搭建,让后台工程师专注功能实现,以便实现逻辑分离,让每个人发挥所长。模板引擎技术的核心是将前端页面指定为模板文件,并用定界符双花括号把文件中标签的跳转地址或数据包起来,后面PHP脚本程序打开该模板文件,并替换变量,进而输出完整的交互页面。
二、简介Blade模板引擎
Blade是laravel框架下的一种简单又强大的模板引擎,Blade 非常快,因为只使用了少量的正则表达式把模板文件编译成原始的php代码。blade模板引擎由模板继承和模板片段驱动,所有的blade模板文件必须使用.blade.php作为文件扩展名。
三、Blade常用语法
1、模块引用,自定义变量
@include('file', ['variable' => $val])
2、扩展子模块
{{-- layout.master --}} @yield('title','默认标题') @section('content') 默认的内容 @show
{{-- home.index --}} @extends('layout.master') @section('title') @parent 新的标题 @stop @section('content') @parent 扩展的内容 @stop
@yield是不可扩展的, @section既可以被替代,又可以被扩展。上面的例子中,模板用@yield和@section分别定义了一个区块,然后在子模板中去定义内容,由于@yield不能被扩展,所以即使加上了@parent也不起作用,输出的内容只有“新的标题”,替换了“默认的标题”。因此最终生成的页面只能是“默认的标题”或者“新的标题”,不能并存。而@section定义的部分,由于使用了@parent关键字,父模板中的内容会被保留,并且添加新的内容,输出的结果是“默认的内容 扩展的内容”。
@section对应的结束关键字,@show, @stop有什么区别呢?
在4.0 版本中,@endsection已经被移除,虽然向下兼容,但是不建议使用。
@show指的是执行到此处时,将该section中的内容输出到页面,而@stop则只是进行内容解析,并且不再处理当前模板中后续对该section的处理,除非用@override覆盖。
通常来说,在首次定义某个section的时候,应该用@show,而在替换它或者扩展它的时候,不应该用@show,应该用@stop。
3、打印变量或者默认值,自动转义变量内容中的html标签,使得html标签原样输出
{{ $name or 'Lily'}}
4、打印变量原始内容,不进行转义
{!! '打印 <script>alert("Hello world!")</script>' !!}
var wxtitle="{!! addslashes($title) !!}"; 阻止转义后,再阻止$title里面的特殊符号影响包在外面的双引号的正常匹配。
5、检查数据是否存在后,再打印数据
{{ isset($name) ? $name : 'Default' }} 或者 {{ $name or 'Default' }}
6、打印数组,中断下面的代码
{{ dd($myArr) }}
7、打印数组,不中断下面的代码
{{ dump($myArr) }}
8、打印文字
@{{ 一段文字 }}
@{{ jsTemplate }}
9、注释
{{-- Comment --}}
10、条件语句
@if(isset($name) && !empty($name)) @elseif() @else @endif
11、循环语句
@for($i = 0; $i < 10; $i++) 输出 {{ $i }} @endfor
@foreach($list as $val) <p>{{ $val[‘url’] }}</p> @endforeach
@foreach($list as $key => $val) <p>{{ $key }} {{ $val[‘url’] }}</p> @endforeach
@while(condition) @endwhile