當頁面被提交請求第一個方法永遠是構造函數。您可以在構造函數裡面初始一些自定義屬性或對象,不過這時候因為頁面還沒有被完全初始化所以多少會有些限制。特別地,您需要使用HttpContext對象。當前可以使用的對象包括QueryString, Form以及Cookies集合,還有Cache對象。註意:在構 ...
當頁面被提交請求第一個方法永遠是構造函數。您可以在構造函數裡面初始一些自定義屬性或對象,不過這時候因為頁面還沒有被完全初始化所以多少會有些限制。特別地,您需要使用HttpContext對象。當前可以使用的對象包括QueryString, Form以及Cookies集合,還有Cache對象。註意:在構造函數里是不允許使用Session的。
下一個將執行的方法是AddParsedSubObject方法,這個方法將添加所有獨立的控制項並把頁面組成一個控制項集合樹,這個方法經常被一些高級的頁面模板解決方案(Page Template Solutions)重寫以便添加頁面內容到頁面模板(Page Template)中一些特殊的控制項中。這個方法遞歸應用到所有的頁面控制項及相應的的每個子控制項,所有的控制項都是在這個方法中開始最早的初始化。http://hovertree.com/menu/aspnet/
頁面類中下一個將執行的方法是DeterminePostBackMode。這個方法允許您修改IsPostBack的值及相關的事件。如果您需要從資料庫中載入ViewState這個方法將特別有用,因為ViewState只有在IsPostBack為真的情況下才會進行恢復。返回空將會導致強制執行非回傳,返回Request.Form則強制執行一個回傳。除非在特殊情況下,否則並不建議去操作這個,因為這個還會影響其他的事件。
下一個將要執行的方法是OnInit方法,一般這是第一個真正被使用的方法。這個方法觸發時,所有頁面定義中的控制項執行初始化,這意味著所有在頁面中定義的值應用到相應的控制項上。不過,ViewState和傳回的值還不會應用到控制項上,因此,任何被代碼或用戶改變的值還沒有被恢復到控制項上。這個方法通常是最好的創建、重創建動態控制項的好地方。
二、恢復及載入
下一個方法,LoadPageStateFromPersistenceMedium只會在頁面被回傳的時候才會被執行。如果因為使用Session或自定義存儲方式,您修改了後面將要提到的影響ViewState保存方式的方法SavePageStateToPersistenceMedium,則這個方法需要被重寫。預設的實現中ViewState是一種Base64格式編碼,並且被保存在頁面的隱藏域中,您可以使用這篇文章中提及的方法修改ViewState按以上兩種方式保存。註意:這個方法並沒有真正載入ViewState到頁面或頁面控制項中。
當得到ViewState後,下一個方法LoadViewSate,將以遞歸的方式恢復ViewState到頁面及各個頁面控制項或子控制項中。這個方法執行後,每個控制項都將恢復到上一次的狀態,但是用戶提交的數據還沒有應用到控制項上,因為他們不是ViewState的一部分。這個方法主要用於恢復您在其他事件中動態生成的控制項的值,他們的值是您手動保存在ViewSate中,並且現在已經失效。
下一個方法是ProcessPostData,這個方法也同樣是回傳的時候才會被執行,並且不允許被重寫,這個是頁面基類的私有方法。這個方法通過匹配控制項的名稱恢復相應的用戶提交的控制項的值,到這一步意味著整個頁面都已經被完全恢復了。唯一要記住的是所有動態控制項的創建必須在這個方法之前。這個方法也是記錄後面的改變事件的方法。
下一個方法是OnLoad方法,通常這是用得最多的方法,因為這個方法是頁面生存期第一個恢復了所有值的地方。大多數代碼根據判斷IsPostBack來決定是否重新設置控制項狀態。您也可以在這個方法中調用Validate並且檢查IsValid的值。也可以在這個方法中創建動態控制項,並且該控制項的所有的方法都會被執行以追上當前頁面的狀態包括ViewSate,不過不包括回傳的值。
三、事件處理
下一個方法還是ProcessPostData,實際上就是前一個方法的另一次調用,它仍然是只在回傳的時候執行並且由於是私有方法不可以被重寫。如果您是第一次看頁面的運行軌跡也許會覺得這個方法有些多餘。但實際上這個方法是必要的因為在OnLoad中創建的動態控制項也需要他們回傳的值。任何在這以後創建的控制項將可以得到他們的ViewState,但是不能再得到他們的回傳的值,並且不會觸發任何值改變事件(Change Event)。
下一個方法,RaiseChangedEvents,也是只在回傳頁面中執行,並且也因為是基類的私有方法所有不能被繼承。在整個頁面生存期中,是在這兒根據之前的ProcessPostData記錄的控制項的值和提交的值是否不同來觸發值改變事件。您也許需要調用Validate或者檢查IsValid的值。這裡並沒有特別的說明多個值改變事件的執行先後順序。
下一個方法,RaisePostBackEvent,同樣是因為是基類的私有方法不能被繼承,同樣也是只在回傳頁面中執行。除非使用了AutoPostBack,不然這是實際提交表單事件執行的地方,特別是按鈕或者其實使用JavaScript提交表單等。如果還沒有被手動調用過並且使用了驗證控制項,那麼Validate會被調用。註意IE中有個BUG有時會允許提交但卻不觸發任何事件。
下一個方法是OnPreRender,一般這是在客戶端展現頁面之前改變頁面及其控制項的最後一次機會。您也可以在這個方法裡面創建動態控制項,並且所有的方法都會被執行以追上當前頁面的狀態包括ViewSate,但是私有方法將不會被執行,這意味著不會有回傳的值並且不會有事件觸發。由於IE中的BUG,這是一個沒有事件趕上PostBack的好地方。
推薦:http://www.cnblogs.com/roucheng/p/netkuangjia.html