研究了有一個月的discuz x2的源代碼。然後有了一些開發的心得。寫心得也算是一種回顧,溫故而知新嘛。
首先,要理解每一個根目錄頁面的大概的加載流程順序。這裡,我就不用根目錄的標准文件了。直接舉例,寫一個新的模塊,它的名字叫做newModule.php。
流程是這樣的:
1. newModule.php首先加載核心的類文件,/source/class/clsss_core.php這個是核心的類文件,這個文件是初始化了整個dz的核心對象,用了單例模式。名字叫做$discuz,這個對象裡面有幾個比較重要的特點。首先,是$_G的參數,被引用到了這個對象的var屬性中,也就是$discuz->var = $_G,然後在對象內用$this->var來操作$_G,在對象外面,比如獨立函數中,使用$_G來操作參數;其次是這個對象裡面引用了所有的其他對象,包括數據庫對象和其他對象,都是用引用來獲得在對象內操作的它們時的同步改變。(其實這個設計原本就比較混亂,不過可以理解,為了照顧以前的設計,純OO的php設計是忌諱這樣的,應該使用注冊表或者組合模式來得更好)
2. 加載支持文件,/source/function/function_core.php文件是所有核心函數,何謂核心函數,核心函數的意思就是在核心類需要實例化的時候,它們就會被使用到。
3. 加載模塊所需要的獨立函數, /source/function/function_newModule.php文件,是該模塊自己所需要的獨立的函數,這些函數應該是從邏輯或者是業務上來說是不能被歸結到某個對象或者類裡面。
4. 加載模塊自定義的類文件,/source/class/class_newModule.php文件,這個文件是新模塊所需要用到類,這個文件可以創建自己的擴展類,特別是領域驅動,或者OO愛好者。
5. 加載模塊自定義的動作文件,什麼叫動作文件,就是url傳值中的mod,這文件的作用是,如果提供最後這個新模塊所需要的最終入口函數。
6. 加載完以上文件,那麼,就可以產生了一個可以供用來使用的大塊php的。所有的必須要的函數都已經准備,就等著ajax或者form的提交或者template的顯示。
需要注意一點是:其實這裡是一個比較標准的,遵從dz原本設計的流程,可以無縫的內簽到dz中,而不會因為系統升級從來影響功能。淡然了。高手們從來都不滿足的,他們一般都會脫離dz的流程。不過,破壞性怎麼樣?就不得而知了。需要因人而異。
我的建議是使用OO和少許的設計模式,來組織代碼,理順業務,這樣擴展性較好,復用率高。當然,喜歡怎麼玩,就怎麼玩。開源的嘛。(其實數據庫感覺設計的可以,如果是我,想必設計不出來,高手勿噴。)