在傳統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)。