本文對延遲載入在常用控制項的實作做簡單的描述。
一、在介面第一次顯示時加載最簡單的延遲加載可以通過控件第一次顯示時加載數據,例如你有很多的頁簽,只有用戶切換到這個頁籤時,才會加載數據。
在.NET的Control中提供SetVisibleCore虛方法,當偵測value是true且第一次呼叫此方法時,呼叫延遲載入。但是我並不推薦這個方法,因為你有更好的地方。
- 如果你的控制項繼承自Form或UserControl,建議重載OnLoad;
- 如果繼承自Control,可以重載OnCreateControl。
下面是延遲載入資料的例子:
public class MyTabPage : TabPage {
protected override void OnCreateControl() {
base.OnCreateControl();
string oldText = this.Text;
this.Text = "Loading..";
//TODO:在這裡呼叫載入資料的方法
this.Text = oldText;
}
}
二、樹控件在第一次展開時載入
TreeView因為所有的節點並不是繼承自Control,所以不能使用上面的方式,但是TreeView提供了OnBeforeExpand虛方法,最簡單的辦法是在你打算實作延遲載入的節點加入一個是否已經載入的標記,當第一次展開時,檢測這個標記。
必須記住你的延遲載入節點在根位置是不能收到這個事件的。
三、在表格中延遲載入。
在Windows程式中,有的使用分頁的方式實現延遲加載,但這種方式的用戶體驗非常的糟糕。如果你希望仍然使用滾動條的話,可以自己實現IBindList接口,內部持有一個數據的ID列表,在表格詢問數據時,才到數據庫加載數據,通常的表格控件都能夠很好的工作。
但這裡有個應該注意的地方,例如用戶按下PageDown時,表格控制項連續的呼叫獲取資料方法,如果每次請求都去調用資料庫,將會很低的效能,應該讓你的程式「預知」到可能要讀下50筆資料了,所以一次多讀50條就可以。
這種方法遇到表格排序的時候就沒辦法了。
以上是延遲加載技術的一般技術,如果你有更好的方法,請指教。