Web Pages 教學課程login
Web Pages 教學課程
作者:php.cn  更新時間:2022-04-11 14:20:28

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" 。

請看下面的 .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>

運行實例»

點擊"運行實例" 按鈕查看線上實例