当前位置:首页 > CMS教程 > 其它CMS > 列表

Laravel 5.1 框架Blade模板引擎用法实例分析

发布:smiling 来源: PHP粉丝网  添加日期:2022-02-02 10:39:58 浏览: 评论:0 

这篇文章主要介绍了Laravel 5.1 框架Blade模板引擎用法,结合实例形式分析了laravel5.1框架Blade模板引擎基本功能、创建、使用方法及相关操作注意事项,需要的朋友可以参考下。

本文实例讲述了Laravel 5.1 框架Blade模板引擎用法,分享给大家供大家参考,具体如下:

为什么要使用blade 它是干什么用的?

blade模板引擎使我们写HTML页面的地方,使用它是因为它能给我们提供很多的遍历,减少代码的重复率 提高开发效率。我们写blade的路径是 resources/view 下,它的文件名后缀是blade.php。

1 继承

继承是相当爽的,它可以从主模板继承所有代码,以免大量的代码重复。这样说比较片面,具体看眼代码吧。

1.1 模板继承拓展 代码片段

首先先创建一个 admin/layout.blade.php:

  1. <!DOCTYPE html> 
  2. <html> 
  3. <head> 
  4.   <title>Learn Laravel-- @yield('title')</title> 
  5. </head> 
  6. <body> 
  7.   @section('navibar'
  8.     The master navigation bar 
  9.   @show 
  10.   <div class="container"
  11.     @yield('content'
  12.   </div> 
  13. </body> 
  14. </html> 

然后创建 admin/home.blade.php 继承自layout:

  1. @extends('admin.layout'
  2. @section('title'
  3.   Home 
  4. @endsection 
  5. @section('navibar'
  6.   @parent 
  7.   <p>增加别的代码 不是完全覆盖</p> 
  8. @endsection 
  9. @section('content'
  10.   <p>Content body</p> 
  11. @endsection 

注册路由 实现控制器方法并展示

  1. Route::group(['prefix' => 'admin''namespace' => 'Admin'], function (){ 
  2.   Route::resource('/''HomeController'); 
  3. }); 
  4.   public function index() 
  5.   { 
  6.     return view('admin.home'); 
  7.   } 

总结: 好了 现在咱先看layout代码 它初始定义了一个HTML简单的模板,在需要拓展的地方都加上了@yield关键字 这代表可填充的一块儿代码片段区域,而@section(navi)是声明了一段片段 然后通过@show来展示。

然后我们创建了home文件,它可以继承自layout 通过@extends() 继承之后就可以使用@section填充layout中的@yield的了,一个yield对应着一个section,关于layout中的@section(navi) 在home中也进行了补充 因为使用了@parent关键字,代表着不覆盖父模板的代码片段 而是在父模板的代码片段最后追加代码,当然啦 如果你要是去掉@parent关键字就会覆盖掉。

如果这么说你还是不明白的话,打开编译器敲一遍 看看结果就清楚了。

1.2 引入一段代码

这也是blade相当强大的地方 当你写了一段HTML之后呢 发现其中有些内容在别的页面下重用率很高,你完全可以把它抽出来放在另一个blade中,然后每当你要使用这段代码时使用@include引入就行了。

首先我们先来创建一个 some.blade.php(至于放在哪里随你便) :

<p>这只是一个演示 所以不浪费时间写太多的HTML</p>

然后在home中引用它吧:

  1. @extends('admin.layout'
  2. @section('title'
  3.   Home 
  4. @endsection 
  5. @section('navibar'
  6.   @parent 
  7.   <p>增加别的代码 不是完全覆盖</p> 
  8. @endsection 
  9. @section('content'
  10.   @include('admin.some'
  11.   <p>Content body</p> 
  12. @endsection 

2 数据展示

这段说说如何将数据传入到一个视图 然后将它展示到页面上。

2.1 数据传入

数据传入有两种种方法 先说第一种 数组方式:

  1. public function index() 
  2.   $name = 'K'
  3.   return view('admin.home', compact('name')); 
  4.   // 也可以这么写 
  5.     return view('admin.home', ['name' => $name]); 

第二种方法是with方法:

  1. public function index() 
  2.   $name = 'K'
  3.   return view('admin.home')->with('name'$name); 

2.2 展示数据

第一种展示方法 {{ }},用双花括号括起来就可以展示传入blade模板的变量,在{{ }} 里是可以使用PHP代码的:

<p>用户:{{ $name }}</p>

第二种展示方法{!!  !!},它是不经过htmlentities函数处理的,所以说你传递的数据是html数据的话 可以使用这种方法:

return view('admin.home')->with('name', '<h1>K</h1>');

<p>用户:{!! $name !!}</p>

3 控制语句

blade模板为了最大化使代码简洁呢 它本身自带了很多控制语句 这跟咱学的PHP很类似,就是if啊 foreach啊什么的

3.1 if控制 - 如果

废话不多说 实例放这你就能懂:

  1. @if(isset($name)) 
  2.   <p>{{ $name }}</p> 
  3. @else 
  4.   <p>None</p> 
  5. @endif 

3.2 unless控制 - 除非

  1. @unless(!isset($name)) 
  2.   <p>{{ $name }}</p> 
  3. @endunless 

3.3 for控制 - 循环

  1. @for ($i = 0; $i < 10; $i++) 
  2.   <p>{{ $i }}</p> 
  3. @endfor 

3.4 foreach控制 - 循环遍历

  1. {{--$names = ['k''l''i'];--}} 
  2. @foreach($names as $name
  3.   <p>{{ $name }}</p> 
  4. @endforeach

Tags: Laravel5.1 Blade

分享到: