ASP.NET - ViewStateの維持
- 前のページ WebForms フォーム
- 次のページ WebForms TextBox
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 を維持することができます。)
- 前のページ WebForms フォーム
- 次のページ WebForms TextBox