ASP.NET ViewState

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>

维持 viewstate 是 asp.net web forms 的默认设置。如果您想不维持 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 方式。当您点击提交按钮,表单值不会消失:

实例

点击实例的右边框架中的查看源代码,您将看到 asp .net 已经在表单中添加了一个隐藏域来维持 viewstate。

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

相关文章