JSON隔離網(wǎng)站布局和頁面實際模塊的內(nèi)容載入
最開始的實現(xiàn)方式是,在服務(wù)端一次性獲取當前頁面的布局結(jié)構(gòu),當前頁面的所有功能模塊,同時通過循環(huán)檢索某一功能模塊屬于哪個容器并合理放置,***獲取具體功能模塊的實際內(nèi)容,一次性輸出完成頁面的顯示。
雖然解決了問題,但這種方式導致了單次請求返回數(shù)據(jù)的急劇增大,特別是在頁面布局復雜、功能模塊繁多時,尤其明顯。
經(jīng)過多方驗證,我決定采取將布局構(gòu)建和內(nèi)容獲取進行隔離、分批次獲取內(nèi)容的方式,以達到減小單次請求數(shù)據(jù)量的目的。具體步驟如下:
***步:采用常規(guī)方式,返回頁面布局HTML結(jié)構(gòu),同時也json方式,返回當前頁面的所有功能模塊基本信息
布局HTML結(jié)構(gòu)示例
1 <div class="enjoosite_layout_container"> |
同步加載的功能模塊JSON
var __widgets = [ "key":"77","columnIndex":0,"sortIndex":1}, "widgetName":"statichtml","key":"76","columnIndex":1,"sortIndex":1}, "key":"82","columnIndex":1,"sortIndex":2} |
第二步:在客戶端,利用js,將功能模塊準確放置如對應(yīng)的布局容器中
我在布局容器HTML結(jié)構(gòu)中,增加了columnindex屬性,在功能模塊的JSON配置中對應(yīng)了columnIndex屬性,因此利用此屬性,輔以jQuery的強大選擇功能,可以非常方便的將功能模塊放置入對應(yīng)容器,同時JSON配置中的sortIndex屬性可以確定同一容器中的先后順序。
第三步:利用jQuery的ajax方法,分批次異步加載具體功能模塊的實際內(nèi)容
我們可以看到,在功能模塊的JSON配置中,每一個功能模塊都具有:widgetName 和 key 2個屬性,widgetName屬性可以確定當前功能模塊的實際類型,如上例中的"statichtml"表示靜態(tài)HTML文本模塊,而key屬性,則對應(yīng)于當前模塊在系統(tǒng)業(yè)務(wù)邏輯中所對應(yīng)的唯一關(guān)鍵值,這個關(guān)鍵值需要配合功能模塊的具體類型進行綜合應(yīng)用,以實現(xiàn)從數(shù)據(jù)庫或XML配置文件獲取內(nèi)容的目的。
在異步獲取功能模塊的實際內(nèi)容環(huán)節(jié),我采取了分批次加載的方式,如果同時發(fā)出內(nèi)容獲取的ajax連接超過10個,那么后續(xù)的請求進入等待隊列,等待前面的10個請求。當前10個請求返回一個時,則立即從等待隊列中提出一個進行連接。這樣,始終以比較平緩的數(shù)據(jù)請求量連接服務(wù)器,而頁面內(nèi)容也始終以比較緩和的方式呈現(xiàn)。
這種方式還值得完善的地方就是,***能夠靈活設(shè)定,哪個功能模塊的加載具有高優(yōu)先級就更好了。呵呵呵,慢慢再完善了。
【編輯推薦】