laravel 5 实现模板主题功能
众所周知,laravel渲染模板是通过View::make()实现的,需要显式指定模板文件路径:
function index()
{
return View::make('index.index');
}
既然这样,我们就可以自己实现模板主题功能,我们只需要将模板文件放到一个主题名称对应的目录里就行,比如默认主题为 default 的话,我们就这样写:
function index()
{
return View::make('default.index.index');
}
自定义主题 custom :
function index()
{
return View::make('custom.index.index');
}
从配置文件中读取主题名:
function index()
{
return View::make(Config::get('app.theme','default').'.index.index');
}
这样基本就实现模板主题化的功能了,但还存在一个问题,那就是custom主题必须实现所有default主题的所有模板,否则会导致某些页面模板文件不存在报错,那么进一步优化:
function index()
{
$theme = Config::get('app.theme','default');
$tpl = $theme.'.index.index';
if (!View::exists($tpl)) {
$tpl = 'default.index.index';
}
return View::make($tpl);
}
就是在渲染模板之前,先检测模板文件是否存在,不存在的话则使用default主题中对应的模板。
这么多行代码,我们可以继续封装一下,这时候要用到Response对象了,我们知道 Response::view() 等同于 View::make(),而Response还有一个方法Response::macro()方法可以用来定义一个宏,我们可以把逻辑封装到宏里面:
Response::macro('render',function($path,$data=array()){
$theme = Config::get('app.theme','default');
$tpl = $theme.'.'.$path;
if (!View::exists($tpl)) {
$tpl = 'default.' . $path;
}
return Response::view($tpl,$data);
});
使用:
function index()
{
$bindings = array(
'title' => '首页'
);
return Response::render('index.index',$bindings);
}
需要注意的是传入模板的变量得通过Response::render的第二个参数。
今天的教程就先到这里吧,后续我们再来深入分析一下,希望大家能够喜欢。
- laravel5.1框架基础之Blade模板继承简单使用方法分析
- 分享5个非常有用的Laravel Blade指令
- Laravel 5框架学习之Blade 简介
- laravel 5 实现模板主题功能(续)
- Laravel框架基础语法与知识点整理【模板变量、输出、include引入子视图等】
- Laravel框架Blade模板简介及模板继承用法分析
- Laravel实现通过blade模板引擎渲染视图
- PHP的Laravel框架中使用AdminLTE模板来编写网站后台界面
- Laravel框架中Blade模板的用法示例
- Laravel中的Blade模板引擎示例详解
- Laravel框架之blade模板新手入门教程及小技巧
- Laravel 5.1 框架Blade模板引擎用法实例分析
相关文章
php获取字符串前几位的实例(substr返回字符串的子串用法)
下面小编就为大家带来一篇php获取字符串前几位的实例(substr返回字符串的子串用法)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-03-03基于curl数据采集之单页面并行采集函数get_htmls的使用
用第一篇的get_html()实现简单的数据采集,由于是一个一个执行才采集数据的传输时间就会是所有页面下载的总时长,一个页面假设1秒,那么10个页面就是10秒了。所幸curl还提供了并行处理的功能2013-04-04Laravel框架FormRequest中重写错误处理的方法
这篇文章主要介绍了Laravel框架FormRequest中重写错误处理的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2019-02-02
最新评论