thinkphp的目錄結構設計經驗總結

用thinkphp開發了好些項目了;最近準備抽空寫一些經驗總結;

希望能給剛開始接觸tp的童鞋們提供一些開發的方案;少走一些彎路;少踩一些坑;

這些絕對都是些精華乾貨;耐着性子閱讀;相信收貨大大的;

可以結合git項目對照研究:http://git.oschina.net/shuaibai123/thinkphp-bjyadmin

先從thinkphp的目錄架構開始吧;


thinkbjy 白俊遙博客
├─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  結構同Home
│  ├─User  結構同Home
├─Public 資源文件目錄
│  ├─install      安裝引導目錄
│  ├─statics      靜態資源目錄
│  │  ├─bootstrap bootstrap框架
│  │  ├─ueditor   ueditor編輯器
│  │  ├─js        jquery等第三方js存放的目錄
│  │  ├─css       animate.css等第三方css目錄
│  │  ├─ ...      
├─Template 視圖文件目錄
│  ├─Public  公共目錄
│  │  ├─js  公共js目錄
│  │  │  ├─base.js 全站都引用的js文件
│  │  │  ├─ ...  
│  │  ├─css  公共css目錄
│  │  │  ├─base.css 全站都引用的css文件  
│  │  │  ├─ ...  
│  │  ├─p_w_picpaths 公共圖片目錄 
│  │  ├─public_head.html  全站通用的公共頭部
│  │  ├─public_foot.html  全站通用的公共底部
│  │  ├─...  
│  ├─Home  前臺Home視圖目錄   
│  │  ├─Public 前臺Home的公共目錄
│  │  │  ├─js  home下調用的js文件目錄
│  │  │  ├─css  home下調用的css文件目錄
│  │  │  ├─p_w_picpaths  home下調用的圖片文件目錄
│  │  ├─Index  首頁文件目錄
│  │  │  ├─index.html 首頁  
│  │  │  ├─ ...
│  ├─Admin  同Home
│  ├─User   同Home
├─Upload  公共上傳目錄
│  ├─p_w_picpaths   上傳的圖片目錄
│  │  ├─avatar  頭像目錄
│  │  ├─ueditor ueditor編輯器上傳的圖片目錄
│  │  │ ...
│  │ ...
├─Runtime 運行時目錄
├─ThinkPHP 框架系統目錄

/Application/Common/Common/function.php 這個作爲常用公共函數文件;

平時經常用的自定義函數都可以放裏面;

比如說 之前寫過的p函數 以符合人類閱讀的方式打印php數組

然後還建議寫:判斷用戶是否登陸的函數、獲取當前登陸用戶id的函數、上傳函數、圖片處理函數、驗證碼函數、分頁函數等等;


/Application/Common/Conf 公共配置項目錄下 我建議至少創建如下3個文件

config.php、db.php、webconfig.php 爲什麼要創建3個配置項文件呢?我來詳細的講解這三個文件的作用;

config.php裏面都是系統的配置項;我們這個文件主要是用來覆蓋框架默認的配置項;這個文件好理解些;

db.php 數據庫的賬號密碼等;單獨放一個文件是因爲很多時候;這個文件需要根據應用安裝的時候填寫的數據庫賬號密碼生成的文件;

webconfig.php 這個文件獨立出來的原因同上;


/Application/Common/Controller 公共控制器目錄

這個目錄下一定要建一個BaseController.class.php 爲了開發維護的方便 我們開發要儘量避免改動框架的文件;

所以呢;爲了不改動框架的Controller.class.php 我們自己建一個BaseController以後所有的Controller都繼承它;

這樣只要在BaseController裏面寫的方法;所有的控制器都繼承到了;都可以用到;

但是呢;我們開發的項目可能會比較複雜;只有一個BaseController會比較雜亂;所以我們還可以根據業務需求再建AdminBaseController.class.php  可以在__construct構造函數中判斷如果不是管理員;禁止訪問;我們只需要所有把所有需要有管理員權限纔可訪問的控制器全部繼承AdminBaseController; 這樣這些控制器就不需要每個都判斷是否是管理員了;

具體可以看 thinkphp集成系列之rbac的升級版auth權限管理系統demo

UserBaseController.class.php 等其他xxBaseController同樣道理;比如說用戶的個人中心必須是登陸狀態纔可訪問等等;


/Application/Common/Model 公共模型目錄

這個目錄一定要建一個BaseModel.class.php 爲什麼呢?

巴拉巴拉。。。

巴拉巴拉。。。

好吧;我在組織語言的時候;發現越寫越多;所以我準備單獨開一片文章來寫BaseModel的問題;

傳送門: thinkphp的model模型的設計經驗總結


/Application/Common/Tag 公共標籤目錄

爲了方便開發;我們還是必須要建一個自定義的標籤庫;My.class.php

什麼是標籤庫呢?我們會發現在模板中tp內置好多標籤很好用;比如說foreach、volist、eq;

官方的文檔傳送門:內置標籤

什麼?不知道怎麼自定義標籤? 好吧;再來個傳送門:thinkphp自定義模板標籤


/Public  資源文件目錄

可以把boostrap、jquery等第三方插件扔到這裏面


/Template 視圖目錄

建議把每個模塊的View都移到這個目錄中集中管理;不然開發的時候各種點目錄切換;那酸爽;誰用誰知道;

/Template/default/Home/Public/js/base.js 和/Template/default/Home/Public/css/base.css 強烈建議全站都引用;裏面寫一些全站都可以用的樣式或函數;比如css的reset;其他的看上面的目錄就可以看明白的;就不多囉嗦了;


/Runtime 運行時目錄

和Template一樣;建議都移到最外層;方便我們刪除緩存;


好吧;認真寫博客真的很耗時;這篇博客寫了整整3個小時;但願能幫到童鞋們;

白俊遙博客

本文爲白俊遙原創文章,轉載無需和我聯繫,但請註明來自白俊遙博客http://www.baijunyao.com                        


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章