通過維持Web表單中的對象的ViewState你可能會省去不少編碼工作。
維持ViewState
在傳統ASP中,當一個表單被提交的時候所有表單值都被清除。假設你提交了一個有很多資訊的表單並且伺服器返回一個錯誤。你不得不返回到表單並更正資訊。你點擊返回按鈕,但是發生了什麼……。所有表單值被清除了,你將不得不從頭開始!網站沒有維持你的ViewState.
在ASP .NET中提交一個表單的時候,表單與所有的表單值一起再現於瀏覽器視窗。怎麼會這樣?這是因為ASP .NET維持你的ViewState。ViewState指明頁面被提交到伺服器時的狀態。該狀態是通過在每個帶有<form runat="server">控制項的頁面中安置一個隱含域來定義的。源檔案可能看起來象是這樣:
<form name="_ctl0" method="post" action="page.aspx" id="_ctl0"><input type="hidden" name="__VIEWSTATE"value="dDwtNTI0ODU5MDE1Ozs+ZBCF2ryjMpeVgUrY2eTj79HNl4Q=" />
.....some code
</form>
對ASP.NET Web表單維持ViewState是預設設定。 如果你想要不維持ViewState,可以在.aspx頁面頂部包含指示:<%@ Page EnableViewState="false" %>,或者對任何控制項加入屬性:EnableViewState="false"。
請看下面的.aspx檔案。它示範了“老方式“的做法。當你點擊提交按鈕,表單值將會消失:
<html>
<body>
<form action="demo_classicasp.aspx" method="post">
Your name: <input type="text" name="fname" size="20">
<input type="submit" value="Submit">
</form>
<%
dim fname
fname=Request.Form("fname")
If fname<>"" Then
Response.Write("Hello " & fname & "!")
End If
%>
</body>
</html>
這是新的ASP .NET方式。當你點擊提交按鈕的時候,表單值將不消失:
<script runat="server">Sub submit(sender As Object, e As EventArgs)lbl1.Text="Hello " & txt1.Text & "!"End Sub</script>
<html><body>
<form runat="server">Your name: <asp:TextBox id="txt1" runat="server" /><asp:Button OnClick="submit" Text="Submit" runat="server" /><p><asp:Label id="lbl1" runat="server" /></p></form>
</body></html>
(在瀏覽器中選擇查看源檔案,會看到ASP .NET已經在表單中添加了一個隱含域來維持ViewState)。