通過在 Web 表單中維持對象的 VIEwState (視圖狀態),您可以省去大量的編碼工作。
當 classic 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>
維持 VIEwState 是 ASP.Net Web 表單的默認設置。如果您不希望維持 VIEwState,請在 .ASPx 頁面的頂部包含指令: <%@ Page EnableViewState="false" %>,或為任意控件添加屬性:EnableVIEwState="false"。
本信息代表文章來源網頁教學webjx.com請大家去www.webjx.com浏覽!
請看下面的 .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。)