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>

白俊遥博客

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

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

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

白俊遥博客

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 回复
白俊遥博客

浮生:写的就是好 想学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 回复