懶載入
滾動頁面時自動獲取數據的方法
在Web應用程序中,系統的瓶頸常在於系統的響應速度。如果系統響應速度過慢,用戶就會出現埋怨情緒,系統的價值也因此會大打折扣。因此,提高系統響應速度,是非常重要的。
Web應用程序做的最多就是和後台資料庫交互,而查詢資料庫是種非常耗時的過程。當資料庫里記錄過多時,查詢優化更顯得尤為重要。為了解決這種問題,有人提出了緩存的概念。緩存就是將用戶頻繁使用的數據放在內存中以便快速訪問。在用戶執行一次查詢操作后,查詢的記錄會放在緩存中。當用戶再次查詢時,系統會首先從緩存中讀取,如果緩存中沒有,再查詢資料庫。緩存技術在一定程度上提升了系統性能,但是當數據量過大時,緩存就不太合適了。因為內存容量有限,把過多的數據放在內存中,會影響電腦性能。而另一種技術,懶載入可以解決這種問題。
懶載入(Load On Demand)是一種獨特而又強大的數據獲取方法,它能夠在用戶滾動頁面的時候自動獲取更多的數據,而新得到的數據不會影響原有數據的顯示,同時最大程度上減少伺服器端的資源耗用。
考慮這樣一個例子:海爾電器是一個非常大的組織機構,它下有1萬多個組織單元。由於組織單元的複雜性,組織單元間也存在著上下級關係。現在的問題是:用戶想加入海爾電器的某個組織單元,他該怎麼選擇到這個組織單元呢?
很容易想到的一個解決方法是:查詢資料庫,把海爾電器的所有組織單元放到一個下拉列表中,讓用戶選擇即可。這樣的確是解決問題了,但是,測試發現,瀏覽器在顯示組織單元數據時就直接假死了。看來,這樣做性能太差,可以不採納。
另一個解決方法就是利用懶載入技術。由於組織單元間存在著上下級關係,那麼組織單元的排列就可以當作一棵樹來處理。在顯示數據時只顯示父節點,點擊父節點時,就能顯示父節點下的子節點。
用戶要選擇某個組織單元,只需點擊該組織單元的父親節點就能找到該組織單元。
可以看出,懶載入節省了系統響應時間,提升了系統性能,非常具有利用價值。