Discuzx2 開發(fā)標準流程筆記
首先,要理解每一個根目錄頁面的大概的加載流程順序。這里,我就不用根目錄的標準文件了。直接舉例,寫一個新的模塊,它的名字叫做newModule.php。
流程是這樣的:
1. newModule.php首先加載核心的類文件,/source/class/clsss_core.php這個是核心的類文件,這個文件是初始化了整個dz的核心對象,用了單例模式。名字叫做$discuz,這個對象里面有幾個比較重要的特點。首先,是$_G的參數(shù),被引用到了這個對象的var屬性中,也就是$discuz->var = $_G,然后在對象內(nèi)用$this->var來操作$_G,在對象外面,比如獨立函數(shù)中,使用$_G來操作參數(shù);其次是這個對象里面引用了所有的其他對象,包括數(shù)據(jù)庫對象和其他對象,都是用引用來獲得在對象內(nèi)操作的它們時的同步改變。(其實這個設(shè)計原本就比較混亂,不過可以理解,為了照顧以前的設(shè)計,純OO的php設(shè)計是忌諱這樣的,應(yīng)該使用注冊表或者組合模式來得更好)
2. 加載支持文件,/source/function/function_core.php文件是所有核心函數(shù),何謂核心函數(shù),核心函數(shù)的意思就是在核心類需要實例化的時候,它們就會被使用到。
3. 加載模塊所需要的獨立函數(shù), /source/function/function_newModule.php文件,是該模塊自己所需要的獨立的函數(shù),這些函數(shù)應(yīng)該是從邏輯或者是業(yè)務(wù)上來說是不能被歸結(jié)到某個對象或者類里面。
4. 加載模塊自定義的類文件,/source/class/class_newModule.php文件,這個文件是新模塊所需要用到類,這個文件可以創(chuàng)建自己的擴展類,特別是領(lǐng)域驅(qū)動,或者OO愛好者。
5. 加載模塊自定義的動作文件,什么叫動作文件,就是url傳值中的mod,這文件的作用是,如果提供最后這個新模塊所需要的最終入口函數(shù)。
6. 加載完以上文件,那么,就可以產(chǎn)生了一個可以供用來使用的大塊php的。所有的必須要的函數(shù)都已經(jīng)準備,就等著ajax或者form的提交或者template的顯示。
需要注意一點是:其實這里是一個比較標準的,遵從dz原本設(shè)計的流程,可以無縫的內(nèi)簽到dz中,而不會因為系統(tǒng)升級從來影響功能。淡然了。高手們從來都不滿足的,他們一般都會脫離dz的流程。不過,破壞性怎么樣?就不得而知了。需要因人而異。
我的建議是使用OO和少許的設(shè)計模式,來組織代碼,理順業(yè)務(wù),這樣擴展性較好,復(fù)用率高。當然,喜歡怎么玩,就怎么玩。開源的嘛。(其實數(shù)據(jù)庫感覺設(shè)計的可以,如果是我,想必設(shè)計不出來,高手勿噴。)
上一篇:Discuz! 應(yīng)用中心操作指南(圖文教程)
欄 目:discuz
下一篇:discuz 查詢語句安全威脅[Query] SELECT /*!40001 SQL
本文地址:http://mengdiqiu.com.cn/a1/discuz/12904.html
您可能感興趣的文章


閱讀排行
本欄相關(guān)
- 01-11Discuz! 6.1.0 圖文安裝教程
- 01-11Discuz! 6.0.0到Discuz! 7.0.0升級教程
- 01-11Discuz!7.0邀請注冊功能詳解
- 01-11DISCUZ!論壇標簽SEO優(yōu)化
- 01-11Discuz!在論壇主題中快速插入UCHome相冊
- 01-11教您為Discuz!論壇輕松更換風(fēng)格
- 01-11Discuz論壇的WAP功能在手機上使用感愛
- 01-11Discuz!7.0論壇幫助功能詳解
- 01-11安裝Discuz!7.0.0 的方法與圖文教程
隨機閱讀
- 01-10使用C語言求解撲克牌的順子及n個骰子
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 08-05織夢dedecms什么時候用欄目交叉功能?
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置
- 08-05DEDE織夢data目錄下的sessions文件夾有什
- 08-05dedecms(織夢)副欄目數(shù)量限制代碼修改
- 01-10C#中split用法實例總結(jié)
- 01-11ajax實現(xiàn)頁面的局部加載
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery