laravel 5 实现模板主题功能(续)
在之前一篇文章中我介绍了通过定义Response宏的方式来实现动态改变模板文件路径以实现主题功能: laravel实现模板主题功能,但后来我发现这种方法有个弊端,在模板中使用@extends必须显式指定模板路径,这可能造成混乱,我决定还是改变思想,主题和主题之间应该是完全隔离的,不存在就是不存在,不要自动去另外的主题中寻找替代的模板。
而原来定义response宏的方式可以实现,但我决定使用更加规范的方法。
laravel的View类里有一个方法 View::addNamespace ,这个方法在手册"开发扩展包"一节中有提到,不得不说Laravel手册排版逻辑混乱,这个方法说明应当放在"视图"章节才是,题外话就不说了,先来说说这个方法吧。
laravel渲染视图有一种写法:
View::make('namespace::path');
//例如 View::make('default::index.index');
如何定义namespace呢,就是通过这个方法啦:
View::addNamespace('default',app_path().'/views/default');
聪明的朋友可能已经感觉到了,这个功能可以助我们实现模板主题化,比如:
//注册蓝色主题
View::addNamespace('blue',app_path().'/views/blue');
//注册红色主题
View::addNamespace('red',app_path().'/views/red');
//注册绿色主题
View::addNamespace('green',app_path().'/views/green');
之后调用:
//渲染绿色主题下的index.index模板
View::make('green::index.index');
然而我们需要事先通过View::addNamespace方法先注册这几个主题的路径映射,并且在渲染的时候需要显式指定namespace.
我感觉不是很方便,难道View不能设定一个默认的namespace吗?这样我们只要一次设置比如:
//我们可以把这个写在 __construct 里面
View::setDefaultNamespace('blue',app_path().'/views/blue');
之后:
//实际上相当于 View::make('blue::index.index');
View::make('index.index');
更进一步,我们可以通过后台设置主题,把主题名写进数据库,前台读取并设置主题:
//假设从数据库中读取配置,Option是模型类
$theme = Option::getByKey('theme');
View::setDefaultNamespace($theme,app_path().'/views/'.$theme);
这样就实现了后台切换主题了。
但是很遗憾,View并没有setDefaultNamespace方法,所以我决定创建一个项目,专门针对laravel进行核心类库扩展,这个功能已经实现,可以查看我的项目:项目地址 ,在src/Keepeye/Laravel/View/查看使用方法吧。
好了,关于laravel模板主题功能的实现,我们就探讨到这里了,希望大家能够喜欢。
- 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和substring的正确用法及相关参数的介绍
这篇文章主要介绍了PHP中substr和substring的正确用法及相关参数介绍的相关资料,需要的朋友可以参考下2015-12-12
最新评论