thinkphp把模板文件View独立出来

示例项目:https://github.com/baijunyao/thinkphp-bjyadmin

thinkphp默认的View都是在/Application各个模块下的;

css、js之类的资源文件是放在/Public目录下;

大致是这个样子的;

thinkphp
├─Application 项目逻辑目录
│  ├─Common 公共模块
│  │  ├─...
│  ├─Home  Home模块
│  │  ├─Controller  Home控制器目录
│  │  ├─...
│  │  ├─View  Home模块下的视图目录
│  │  │  ├─Index
│  │  │  │  ├─index.html
│  │  │  │  ├─...
│  │  │  ├─Tag
│  │  │  │  ├─index.html
│  │  │  │  ├─add.html
│  │  │  │  ├─edit.html
│  │  │  │  ├─...
│  ├─Admin  Admin模块
│  │  ├─Controller  Admin控制器目录
│  │  ├─...
│  │  ├─View  Admin模块下的视图目录
│  │  │  ├─Index
│  │  │  │  ├─index.html
│  │  │  │  ├─...
│  │  │  ├─Article
│  │  │  │  ├─index.html
│  │  │  │  ├─add.html
│  │  │  │  ├─edit.html
│  │  │  │  ├─...
│  ├─...
├─Public 资源文件目录
│  ├─Home  前台Home视图目录   
│  │  ├─Public 前台Home的公共目录
│  │  │  ├─js  home下调用的js文件目录
│  │  │  ├─css  home下调用的css文件目录
│  │  │  ├─images  home下调用的图片文件目录 
│  ├─Admin  前台Home视图目录   
│  │  ├─Public 前台Home的公共目录
│  │  │  ├─js  home下调用的js文件目录
│  │  │  ├─css  home下调用的css文件目录
│  │  │  ├─images  home下调用的图片文件目录 
│  ├─...
├─ThinkPHP 框架系统目录

但是在实际开发中;

这样把View目录分散到各个模块下是有很多弊端的;

首先开发多套主题相当之麻烦相当之混乱;

再个使用gulp这类前端工具很不便利;

我们想要的是某个目录下全是原始代码;

另一个目录下全是压缩后的html、js、css等;

燃鹅;这样一个小愿望在面对这样的目录结构时;

我的表情是 黑人问号.jpg;


所以;我是把所有的模板文件和js、css等独立出来放在根目录下的/tpl中的;

这里偷个懒;直接把以前写的目录结构拿来了;

thinkphp-bjyadmin
├─Application 项目逻辑目录
│  ├─Common 公共模块
│  │  ├─Common  公共函数目录
│  │  │  ├─functioin.php 公共函数php文件
│  │  ├─Conf  公共配置文件目录
│  │  │  ├─config.php  tp的配置 用于覆盖框架默认配置项
│  │  │  ├─db.php  数据库配置 用户名 密码等
│  │  │  ├─webconfig.php  项目的配置;网站名;是否开启网站等
│  │  ├─Controller  公共控制器目录 
│  │  │  ├─BaseController.class.php 应用最基础的控制器
│  │  │  ├─HomeBaseController.class.php  Home基础控制器继承BaseController
│  │  │  ├─AdminBaseController.class.php  Admin基础控制器继承BaseController
│  │  │  ├─UserBaseController.class.php  User基础控制器继承BaseController
│  │  │  ├─...
│  │  ├─Model  公共模型目录
│  │  │  ├─BaseModel.class.php  应用最基础的Model
│  │  │  ├─ArticleModel.class.php 文章model  继承BaseModel
│  │  │  ├─UserModel.class.php  用户model 继承BaseModel
│  │  │  ├─...
│  │  ├─Tag  公共标签目录
│  │  │  ├─My.class.php  自定义的标签库
│  │  │  ├─...
│  ├─Home  Home模块
│  │  ├─Controller  Home控制器目录 继承HomeBaseController
│  │  │  ├─ArticleController.class.php 文章控制器目录  
│  │  │  ├─IndexController.class.php  首页控制器
│  │  │  ├─ ...  
│  ├─Admin  Admin模块
│  │  ├─Controller  Admin控制器目录 继承AdminBaseController
│  │  │  ├─IndexController.class.php  后台管理首页控制器
│  │  │  ├─ ...  
│  ├─User  User模块
│  │  ├─Controller  User控制器目录 继承UserBaseController
│  │  │  ├─IndexController.class.php  用户个人中心首页控制器
│  │  │  ├─ ...  
├─Public 资源文件目录
│  ├─install      安装引导目录
│  ├─statics      静态资源目录
│  │  ├─bootstrap bootstrap框架
│  │  ├─ueditor   ueditor编辑器
│  │  ├─js        jquery等第三方js存放的目录
│  │  ├─css       animate.css等第三方css目录
│  │  ├─ ...      
├─tpl 视图文件目录
│  ├─Public  公共目录
│  │  ├─js  公共js目录
│  │  │  ├─base.js 全站都引用的js文件
│  │  │  ├─ ...  
│  │  ├─css  公共css目录
│  │  │  ├─base.css 全站都引用的css文件  
│  │  │  ├─ ...  
│  │  ├─images 公共图片目录 
│  │  ├─public_head.html  全站通用的公共头部
│  │  ├─public_foot.html  全站通用的公共底部
│  │  ├─...  
│  ├─Home  前台Home视图目录   
│  │  ├─Public 前台Home的公共目录
│  │  │  ├─js  home下调用的js文件目录
│  │  │  ├─css  home下调用的css文件目录
│  │  │  ├─images  home下调用的图片文件目录
│  │  ├─Index  首页文件目录
│  │  │  ├─index.html 首页  
│  │  │  ├─ ...
│  ├─Admin  同Home
│  ├─User   同Home
├─Upload  公共上传目录
│  ├─images   上传的图片目录
│  │  ├─avatar  头像目录
│  │  ├─ueditor ueditor编辑器上传的图片目录
│  │  │ ...
│  │ ...
├─Runtime 缓存目录
├─ThinkPHP 框架系统目录

其他目录的设计原则可以回顾 thinkphp的目录结构设计经验总结

我们把html独立出来后;最直观的感受是;

结构上前后端更加独立了;以前是大杂烩;

而且我们一言不合;想改目录就改目录;相当自由;


那要实现这样的结构非常简单;

只需要在根目录的入口文件index.php文件中定义TMPL_PATH就可以了;

原本的代码是这样的;

<?php
// +----------------------------------------------------------------------
// | ThinkPHP [ WE CAN DO IT JUST THINK ]
// +----------------------------------------------------------------------
// | Copyright (c) 2006-2014 http://thinkphp.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: liu21st <liu21st@gmail.com>
// +----------------------------------------------------------------------

// 应用入口文件

// 检测PHP环境
if(version_compare(PHP_VERSION,'5.3.0','<'))  die('require PHP > 5.3.0 !');

// 开启调试模式 建议开发阶段开启 部署阶段注释或者设为false
define('APP_DEBUG',True);

// 定义应用目录
define('APP_PATH','./Application/');

// 引入ThinkPHP入口文件
require './ThinkPHP/ThinkPHP.php';

// 亲^_^ 后面不需要任何代码了 就是如此简单

修改后的代码是这样的;

<?php
// +----------------------------------------------------------------------
// | ThinkPHP [ WE CAN DO IT JUST THINK ]
// +----------------------------------------------------------------------
// | Copyright (c) 2006-2014 http://thinkphp.cn All rights reserved.
// +----------------------------------------------------------------------
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
// +----------------------------------------------------------------------
// | Author: liu21st <liu21st@gmail.com>
// +----------------------------------------------------------------------

// 应用入口文件

// 检测PHP环境
if(version_compare(PHP_VERSION,'5.3.0','<'))  die('require PHP > 5.3.0 !');

// 开启调试模式 建议开发阶段开启 部署阶段注释或者设为false
define('APP_DEBUG',True);

// 定义应用目录
define('APP_PATH','./Application/');

// 定义缓存目录
define('RUNTIME_PATH','./Runtime/');

// 定义模板文件默认目录
define("TMPL_PATH","./tpl/");

// 引入ThinkPHP入口文件
require './ThinkPHP/ThinkPHP.php';

// 亲^_^ 后面不需要任何代码了 就是如此简单

细心的童鞋可能发现了;这里还定义了个RUNTIME_PATH是为嘛呢?

买一送一;

这里是顺便把缓存文件Runtime文件夹也从/Application中独立到根目录下了;

当项目上线后;关闭了调试模式;来这里删缓存文件方便;


恩;好吧;我承认我是处女座;

就是喜欢/Application下只是php业务代码;

就是喜欢纯粹干净的感觉;

排斥各种混杂;


当然;到这里已经可以结束了;

但是我们还可以做的更好;

还需要在/Application/Common/Conf/config.php文件中定义一些目录;

<?php
return array(
    //'配置项'=>'配置值'
    'TMPL_PARSE_STRING'      => array(    // 定义常用路径
        '__PUBLIC__'         => __ROOT__.'/Public',
        '__HOME_CSS__'       => __ROOT__.trim(TMPL_PATH,'.').'Home/Public/css',
        '__HOME_JS__'        => __ROOT__.trim(TMPL_PATH,'.').'Home/Public/js',
        '__HOME_IMAGES__'    => __ROOT__.trim(TMPL_PATH,'.').'Home/Public/images',
        '__ADMIN_CSS__'      => __ROOT__.trim(TMPL_PATH,'.').'Admin/Public/css',
        '__ADMIN_JS__'       => __ROOT__.trim(TMPL_PATH,'.').'Admin/Public/js',
        '__ADMIN_IMAGES__'   => __ROOT__.trim(TMPL_PATH,'.').'Admin/Public/images',
        '__ADMIN_ACEADMIN__' => __ROOT__.trim(TMPL_PATH,'.').'Admin/Public/aceadmin',
        '__PUBLIC_CSS__'     => __ROOT__.trim(TMPL_PATH,'.').'Public/css',
        '__PUBLIC_JS__'      => __ROOT__.trim(TMPL_PATH,'.').'Public/js',
        '__PUBLIC_IMAGES__'  => __ROOT__.trim(TMPL_PATH,'.').'Public/images',
        '__USER_CSS__'       => __ROOT__.trim(TMPL_PATH,'.').'User/Public/css',
        '__USER_JS__'        => __ROOT__.trim(TMPL_PATH,'.').'User/Public/js',
        '__USER_IMAGES__'    => __ROOT__.trim(TMPL_PATH,'.').'User/Public/images',
        '__APP_CSS__'        => __ROOT__.trim(TMPL_PATH,'.').'App/Public/css',
        '__APP_JS__'         => __ROOT__.trim(TMPL_PATH,'.').'App/Public/js',
        '__APP_IMAGES__'     => __ROOT__.trim(TMPL_PATH,'.').'App/Public/images'
    ),
);

然后以后在html中就使用这些路径了;

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>白俊遥博客</title>
    <css file="__USER_CSS__/index.css" />
</head>
<body>

<js file="__USER_JS__/index.js" />
</body>
</html>

白俊遥博客

白俊遥博客
请先登录后发表评论
  • 最新评论
  • 总共23条评论
白俊遥博客

ALLeys:博主 控制器里display的话 是直接this->display()  还是需要带路径 例如 this-display('tpl/Home.')这样,因为你不是自定义模版目录了吗 

2017-02-03 20:02:09 回复

白俊遥博客

老马39:为什么没有文章收藏功能!!!!!!!!!!!!!!!!!

2017-01-29 09:27:52 回复

白俊遥博客

全世界:很不习惯这个!我还是先按照以前的惯例思维去写的!至少我拿一个新的框架,把你的往里面搬的时候,我就疯了!样式全丢!然后慢慢理好揪心!最后把配置路径部分删了,全部用__PUBLIC__

2017-01-08 15:10:56 回复

白俊遥博客

杨名:谢谢大神,我是今年去培训班学习的,马上毕业了,感觉只会基础的php语法,但是对这个还是很感兴趣,请问有什么好的建议吗?你这个博客源码我也研究很久了,感觉自己的能力离找工作很遥远!看得出你也很忙,能给点建议最好!

2016-12-22 23:10:43 回复

白俊遥博客
  • 云淡风晴 回复 杨名:保持兴趣;然后在编程中找到乐趣;坚持下去;肯定是会有所成就的;没有那么难;也没有什么捷径;就是不断的敲代码;3点建议:写博客系统或者是别的程序并开源道github等平台、在写程序的过程中遇到问题去stackoverflow 或者国内的 segmentfault 问答网站上提问;也尝试着回答一些别人提出的问题、开发出了博客程序或者使用县城的程序多总结写技术文章;希望对迷茫的你有所帮助;
  • 2016-12-22 23:21:45 回复
白俊遥博客
  • 杨名 回复 云淡风晴:谢谢!
  • 2016-12-22 23:42:53 回复
白俊遥博客

杨名白俊遥博客

2016-12-16 21:20:40 回复

白俊遥博客

杨名:你好,这个博客有大概的构造思路吗,我看了好几天很多地方流程不懂- -!

2016-12-16 21:20:12 回复

白俊遥博客
  • 云淡风晴 回复 杨名:看下博客程序有什么功能;然后自己去实现的过程中慢慢就理解了;
  • 2016-12-22 22:57:24 回复
白俊遥博客
  • 杨名 回复 云淡风晴:谢谢大神,我是今年去培训班学习的,马上毕业了,感觉只会基础的php语法,但是对这个还是很感兴趣,请问有什么好的建议吗?你这个博客源码我也研究很久了,感觉自己的能力离找工作很遥远!
  • 2016-12-22 23:09:11 回复
白俊遥博客

Serene:tp3.2.3的TMPL_PATH的配置不起作用,是什么原因呢?示例代码在本地可以运行,但新建的项目就不起作用。

2016-12-06 10:03:45 回复

白俊遥博客
  • 云淡风晴 回复 Serene:我新建了个项目测试是可以的;再检查检查代码?
  • 2016-12-11 22:34:27 回复
白俊遥博客
  • Serene 回复 云淡风晴:在入口文件里定义TMPL_PATH。define('TMPL_PATH','./tpl/');但并没有把view层分离出来。我配置VIEW_PATH也是没有效果。不知道是什么原因。
  • 2016-12-12 10:35:07 回复
白俊遥博客
  • 云淡风晴 回复 Serene:你下载我的程序;看可以么?然后对照你的;
  • 2016-12-22 23:23:06 回复
白俊遥博客

Pmd:不好意思 ,白哥,哈哈 ,测试了一下。我看了下你的源码 ,懂的怎么过滤表情标签了。实在抱歉哈

2016-11-15 11:24:04 回复

白俊遥博客

Pmd:<img src="https://ss0.bdstatic.com/5aV1bjqh_Q23odCf/static/superman/img/logo_top_ca79a146.png" title="3" alt="3">

2016-11-15 11:05:01 回复

白俊遥博客

简笔画:// 定义模板文件默认目录define("TMPL_PATH","./tpl/"); 我加了这句不好像  求大神指点

2016-11-05 09:27:52 回复

白俊遥博客
  • 云淡风晴 回复 简笔画:把示例项目下载到本地;看是否可以呢?
  • 2016-11-07 22:47:18 回复
白俊遥博客

简笔画:3.2 这样用好像不行啊  

2016-11-05 09:26:58 回复

白俊遥博客

乐臣氏:自定义手机的模板样式,该怎么封装进去好?

2016-10-31 21:59:10 回复

白俊遥博客
  • 云淡风晴 回复 乐臣氏:可以在index.php中判断是手机还是电脑访问;然后定义不同的TMPL_PATH;
  • 2016-10-31 23:37:40 回复
白俊遥博客

妒妒涵:学习了

2016-10-25 14:11:51 回复

白俊遥博客

扬笑留影:我不希望所有的admin模板下都引入public下所有的css,那该怎么办。原因是我要做一个后台的登陆页,但是后台所有页面左边都有一块灰色区域

2016-10-12 11:15:35 回复

白俊遥博客
  • 云淡风晴 回复 扬笑留影:可以自定义标签;或者模板继承;
  • 2016-10-13 23:54:46 回复
白俊遥博客

xuAn:博主好人呐

2016-10-11 11:47:32 回复

白俊遥博客

╰(*´︶`*)╯:博主,你的博客的js是怎么引入到首页的?我加了一个站长统计,然后不知道是怎么加到首页的,呃呃呃

2016-10-10 18:24:12 回复

白俊遥博客
  • 云淡风晴 回复 ╰(*´︶`*)╯:js我是写了标签的:http://baijunyao.com/article/21  站长统计可以直接在后台配置;
  • 2016-10-11 23:05:35 回复
白俊遥博客

随风轻去:博主啊 可以开始TP5了啊 天天都来看看 简直大爱啊 希望能跟上啊   要上天了

2016-10-09 23:04:23 回复

白俊遥博客

Antion Zhou:博主!!!Thinkphp怎么调用自定义类啊!!!!!!跪求

2016-10-08 16:24:57 回复

白俊遥博客
  • 云淡风晴 回复 Antion Zhou:官方手册有的:http://document.thinkphp.cn/manual_3_2.html#autoload
  • 2016-10-09 07:17:13 回复
白俊遥博客

晴天白俊遥博客白俊遥博客

2016-09-28 20:37:33 回复

白俊遥博客
  • 今网科技_李潇 回复 晴天白俊遥博客
  • 2016-10-13 17:03:15 回复
白俊遥博客

晴天白俊遥博客

2016-09-28 20:37:16 回复

白俊遥博客

大海:有点爱上博主了

2016-09-28 19:18:51 回复

白俊遥博客
  • 云淡风晴 回复 大海:你就死了这条心吧;我不喜欢男的;
  • 2016-09-28 22:06:15 回复
白俊遥博客
  • 简简单单 回复 云淡风晴:支持一个6666,万一是女的呢
  • 2016-09-29 10:49:57 回复
白俊遥博客
  • 飞啊飞啊灰啊灰 回复 简简单单:男的掰弯就行,哈哈哈哈哈
  • 2016-09-30 15:20:27 回复
白俊遥博客
  • ‭清真猪肉罐头 回复 飞啊飞啊灰啊灰白俊遥博客好主意
  • 2016-10-10 14:30:22 回复
白俊遥博客
  • ‭清真猪肉罐头 回复 ‭清真猪肉罐头:请先登陆后回复评论
  • 2016-10-10 14:31:01 回复
白俊遥博客
  • 江城小白 回复 ‭清真猪肉罐头:你这个名字取得有意思啊,伊斯兰教听到要弄死你啊!
  • 2017-01-20 13:52:11 回复
白俊遥博客

浮生:写的就是好 想学php语言 但是不知道从哪学起 之前学的c# 现在学php该去哪学 请博主指导下

2016-09-26 17:48:59 回复

白俊遥博客
  • 云淡风晴 回复 浮生:先耐心把官方手册看2遍;然后找一个框架;把框架的手册再看2遍;再然后开始尝试用框架写2个项目;最后找一家用你学的框架做开发的公司;这就入门了;
  • 2016-09-28 00:06:20 回复
白俊遥博客
  • 晴天 回复 云淡风晴:有道理
  • 2016-09-28 20:45:12 回复
白俊遥博客
  • 浮生 回复 云淡风晴:谢谢
  • 2016-10-03 23:17:08 回复
白俊遥博客
  • 海晨 回复 云淡风晴白俊遥博客第一家公司的项目、就当练手即可~~
  • 2016-10-16 03:12:53 回复
白俊遥博客

Oyghan:你好,我请教一下你,你列表页的路由是怎么写的?就是分类页带分页的路由怎么写呢?

2016-09-25 23:20:45 回复

白俊遥博客
  • 云淡风晴 回复 Oyghan:我路由是在这定义的/Application/Home/Conf/config.php
  • 2016-09-28 00:03:57 回复