PageStatePersister.ViewState 屬性
定義
重要
部分資訊涉及發行前產品,在發行之前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。
取得或設定物件,表示對 Web 伺服器的 HTTP 要求之間,目前 Page 物件所包含的控制項用以保存的資料。
public:
property System::Object ^ ViewState { System::Object ^ get(); void set(System::Object ^ value); };
public object ViewState { get; set; }
member this.ViewState : obj with get, set
Public Property ViewState As Object
屬性值
包含檢視狀態資料的物件。
範例
下列程式代碼範例示範衍生自 類別的 PageStatePersister 類別如何初始化 ViewState 屬性。 在此範例中 ViewState ,屬性已指派給 First 物件的欄位 Pair ,並使用 物件串行化 ObjectStateFormatter ,這是介面的 IStateFormatter 實例。 Load呼叫 方法時,ObjectStateFormatter會使用 介面來還原串行化檢視狀態資訊,並從ViewState產生的Pair物件First欄位初始化 屬性。 此程式代碼範例是針對 類別提供的較大範例的 PageStatePersister 一部分。
//
// Load ViewState and ControlState.
//
public override void Load()
{
Stream stateStream = GetSecureStream();
// Read the state string, using the StateFormatter.
StreamReader reader = new StreamReader(stateStream);
IStateFormatter formatter = this.StateFormatter;
string fileContents = reader.ReadToEnd();
// Deserilize returns the Pair object that is serialized in
// the Save method.
Pair statePair = (Pair)formatter.Deserialize(fileContents);
ViewState = statePair.First;
ControlState = statePair.Second;
reader.Close();
stateStream.Close();
}
'
' Load ViewState and ControlState.
'
Public Overrides Sub Load()
Dim stateStream As Stream
stateStream = GetSecureStream()
' Read the state string, using the StateFormatter.
Dim reader As New StreamReader(stateStream)
Dim serializedStatePair As String
serializedStatePair = reader.ReadToEnd
Dim statePair As Pair
Dim formatter As IStateFormatter
formatter = Me.StateFormatter
' Deserilize returns the Pair object that is serialized in
' the Save method.
statePair = CType(formatter.Deserialize(serializedStatePair), Pair)
ViewState = statePair.First
ControlState = statePair.Second
reader.Close()
stateStream.Close()
End Sub
備註
檢視狀態是 Web 伺服器控制項必須自行運作及轉譯的狀態數據字典。 控制開發人員通常會使用 ViewState 屬性來存取檢視狀態物件。 檢視狀態會在層級停用 Page 檢視狀態時受到影響,因此控件在這些案例中可能無法正確運作。 如需開發控件時使用 ViewState 和控制狀態的詳細資訊,請參閱 開發自定義 ASP.NET 伺服器控制件。