示例项目: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>
本文为白俊遥原创文章,转载无需和我联系,但请注明来自白俊遥博客https://baijunyao.com 欢迎捐赠赞赏加入组织创建QQ群及捐赠渠道
_ATIU* :结构很清晰,非常实用啊,大神辛苦了
2018-09-07 09:24:12 回复
缺氧 :按照大神的目录结构整理在框架内了,以后可以直接拿来使用了
2017-09-15 13:34:43 回复
炎归正专 :奇怪,下载楼主的项目view是可以分离开的,但自己创建tp3.2.3的TMPL_PATH的配置不起作用的
2017-05-16 15:54:22 回复
炎归正专 :也不知道怎么就好了,怎么都没有改
2017-05-16 16:31:01 回复
沁雪澜 :
2017-05-10 11:41:45 回复
天 :刚在百度找到大神,clone了源码,发现有个文件夹tpl_src,这个是可以删除的吗?
2017-03-12 10:42:19 回复
hiwangqi :博主 控制器里display的话 是直接this->display() 还是需要带路径 例如 this-display('tpl/Home.')这样,因为你不是自定义模版目录了吗
2017-02-03 20:02:09 回复
老马⁴º :为什么没有文章收藏功能!!!!!!!!!!!!!!!!!
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 回复
云淡风晴 :我新建了个项目测试是可以的;再检查检查代码?
2016-12-11 22:34:27 回复
Serene :在入口文件里定义TMPL_PATH。define('TMPL_PATH','./tpl/');但并没有把view层分离出来。我配置VIEW_PATH也是没有效果。不知道是什么原因。
2016-12-12 10:35:07 回复
云淡风晴 :你下载我的程序;看可以么?然后对照你的;
2016-12-22 23:23:06 回复
炎归正专 :你view分离出来了吗?
2017-05-16 15:55:35 回复
Pmd :不好意思 ,白哥,哈哈 ,测试了一下。我看了下你的源码 ,懂的怎么过滤表情标签了。实在抱歉哈
2016-11-15 11:24:04 回复
Pmd :[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 回复
闹比i :自定义手机的模板样式,该怎么封装进去好?
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 回复
云淡风晴 :官方手册有的: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 回复
云淡风晴 :我路由是在这定义的/Application/Home/Conf/config.php
2016-09-28 00:03:57 回复
最新评论