Web 表單檢視狀態
ASP.NET Web Forms - 維持ViewState
#透過在您的Web Form 中維持物件的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#</form&
#維持ViewState 是ASP.NET Web Forms 的預設設定。如果您想要不維持 ViewState,請在 .aspx 頁面頂部包含指令 <%@ Page EnableViewState="false" %> ,或向任意控制項新增屬性 EnableViewState="false" 。 <input type= "hidden" name="__VIEWSTATE"
value="dDwtNTI0ODU5MDE1Ozs+ZBCF2ryjMpeVgUrY2eTj79HNl4Q=" />
.....#some code
##</form#</form&
請看下面的 .aspx 檔案。它演示了"老"的運行方式。當您點擊提交按鈕,表單值將會消失:
##實例
<!DOCTYPE html> <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 方式。當您點擊提交按鈕,表單值不會消失:
點擊實例的右邊框架中的檢視原始碼,您將看到ASP .NET 已經在表單中新增了一個隱藏域來維持ViewState。
實例
<script runat="server"> Sub submit(sender As Object, e As EventArgs) lbl1.Text="Hello " & txt1.Text & "!" End Sub </script> <!DOCTYPE html> <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>
運行實例»
點擊"運行實例" 按鈕查看線上實例