ASP.NET - ViewStateの維持

Webフォームで对象的ViewState(ビューステート)を維持することで、多くのコーディング作業を省略できます。

ViewState(ビューステート)の維持

classic ASPのフォームが提出されたとき、すべてのフォーム値がクリアされます。多くの情報を持つフォームを提出し、サーバーからエラーが返された場合を想像してみてください。フォームに戻り、情報を修正する必要があります。戻るボタンをクリックするとどうなるか... すべてのフォーム値がクリアされ、すべてを再び始めなければなりません。サイトはViewStateを維持しません。

ASP .NETのフォームが提出されたとき、フォームはすべてのフォーム値とともに再び表示されます。どうやって実現しているのでしょうか?これはASP .NETがViewStateを維持しているためです。ViewStateはページがサーバーに提出されたときにその状態を示します。ページの各フォーム 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"。

以下の .aspx ファイルを見てください。古い実行方法を示しています。提出ボタンをクリックすると、フォームの値が消えます:

<html>
<body>
<form action="demo_classicasp.aspx" method="post">
あなたの名前: <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">
あなたの名前: <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 を維持することができます。)