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


Posted in PHP onJanuary 04, 2020

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

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

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

1 继承

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

1.1 模板继承拓展 代码片段

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

<!DOCTYPE html>
<html>
<head>
  <title>Learn Laravel-- @yield('title')</title>
</head>
<body>
  @section('navibar')
    The master navigation bar
  @show
  <div class="container">
    @yield('content')
  </div>
</body>
</html>

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

@extends('admin.layout')
@section('title')
  Home
@endsection
@section('navibar')
  @parent
  <p>增加别的代码 不是完全覆盖</p>
@endsection
@section('content')
  <p>Content body</p>
@endsection

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

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

总结: 好了 现在咱先看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中引用它吧:

@extends('admin.layout')
@section('title')
  Home
@endsection
@section('navibar')
  @parent
  <p>增加别的代码 不是完全覆盖</p>
@endsection
@section('content')
  @include('admin.some')
  <p>Content body</p>
@endsection

2 数据展示

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

2.1 数据传入

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

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

第二种方法是with方法:

public function index()
  {
    $name = 'K';
    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控制 - 如果

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

@if(isset($name))
    <p>{{ $name }}</p>
  @else
    <p>None</p>
  @endif

3.2 unless控制 - 除非

@unless(!isset($name))
    <p>{{ $name }}</p>
  @endunless

3.3 for控制 - 循环

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

3.4 foreach控制 - 循环遍历

{{--$names = ['k', 'l', 'i'];--}}
  @foreach($names as $name)
    <p>{{ $name }}</p>
  @endforeach

希望本文所述对大家基于Laravel框架的PHP程序设计有所帮助。

PHP 相关文章推荐
获取用户Ip地址通用方法与常见安全隐患(HTTP_X_FORWARDED_FOR)
Jun 01 PHP
基于php无限分类的深入理解
Jun 02 PHP
关于svn冲突的解决方法
Jun 21 PHP
php判断类是否存在函数class_exists用法分析
Nov 14 PHP
ThinkPHP实现非标准名称数据表快速创建模型的方法
Nov 29 PHP
thinkphp在低版本Nginx 下支持PATHINFO的方法分享
May 27 PHP
php判断用户是否关注微信公众号
Jul 22 PHP
php rmdir使用递归函数删除非空目录实例详解
Oct 20 PHP
详解php中 === 的使用
Oct 24 PHP
详谈PHP面向对象中常用的关键字和魔术方法
Feb 04 PHP
php面向对象的用户登录身份验证
Jun 08 PHP
Laravel 已登陆用户再次查看登陆页面的自动跳转设置方法
Sep 30 PHP
Laravel5.1 框架控制器基础用法实例分析
Jan 04 #PHP
Laravel5.1框架路由分组用法实例分析
Jan 04 #PHP
Laravel5.1 框架路由基础详解
Jan 04 #PHP
PHP配合fiddler抓包抓取微信指数小程序数据的实现方法分析
Jan 02 #PHP
PHP+MySQL实现在线测试答题实例
Jan 02 #PHP
PHP CURL实现模拟登陆并上传文件操作示例
Jan 02 #PHP
TP3.2.3框架使用CKeditor编辑器在页面中上传图片的方法分析
Dec 31 #PHP
You might like
网站上面有这种切换效果
2006/06/26 Javascript
离开页面时检测表单元素是否被修改,提示保存的js代码
2010/08/25 Javascript
js对数字的格式化使用说明
2011/01/12 Javascript
EXT窗口Window及对话框MessageBox
2011/01/27 Javascript
可兼容IE的获取及设置cookie的jquery.cookie函数方法
2013/09/02 Javascript
jquery快捷动态绑定键盘事件的操作函数代码
2013/10/17 Javascript
多个$(document).ready()的执行顺序实例分析
2014/07/26 Javascript
js中string转int把String类型转化成int类型
2014/08/13 Javascript
node.js中的fs.writeFileSync方法使用说明
2014/12/14 Javascript
用JS动态设置CSS样式常见方法小结(推荐)
2016/11/10 Javascript
localStorage实现便签小程序
2016/11/28 Javascript
基于js中style.width与offsetWidth的区别(详解)
2017/11/12 Javascript
Vue工程模板文件 webpack打包配置方法
2017/12/26 Javascript
Vue项目使用CDN优化首屏加载问题
2018/04/01 Javascript
vue源码解析之事件机制原理
2018/04/21 Javascript
VUE 自定义组件模板的方法详解
2019/08/30 Javascript
JS正则表达式验证端口范围(0-65535)
2020/01/06 Javascript
jQuery实现数字华容道小游戏(实例代码)
2020/01/16 jQuery
OpenLayers3实现地图显示功能
2020/09/25 Javascript
javascript实现搜索筛选功能实例代码
2020/11/12 Javascript
Python IDE PyCharm的基本快捷键和配置简介
2015/11/04 Python
Python实现二叉堆
2016/02/03 Python
Python实现的圆形绘制(画圆)示例
2018/01/31 Python
解决PyCharm同目录下导入模块会报错的问题
2018/10/13 Python
python3模拟实现xshell远程执行liunx命令的方法
2019/07/12 Python
在Keras中CNN联合LSTM进行分类实例
2020/06/29 Python
爱普生美国官网:Epson美国
2018/11/05 全球购物
不用游标的SQL语句有哪些
2012/09/07 面试题
会计毕业生自我鉴定
2013/11/04 职场文书
优秀团员自我评价范文
2014/04/23 职场文书
2014年大学生党员自我评议
2014/09/22 职场文书
群众路线教育实践活动学习心得体会
2014/10/30 职场文书
合理化建议书范文
2015/09/14 职场文书
2019新学期家长会工作计划
2019/08/21 职场文书
python正则表达式re.search()的基本使用教程
2021/05/21 Python
如何用H5实现好玩的2048小游戏
2022/07/23 HTML / CSS