よろしくお願いします
現在、vs.net 2005 で web ページを作成しています
そこで質問があるので、ご教授の程よろしくお願いします。
test.aspx
Table コントロール配置:Table1
Button コントロール配置:Button1
Label コントロール配置:Label1
Label コントロール配置:Label2
test.aspx.vb
Partial Class test
Inherits System.Web.UI.Page
Protected Sub form1_Load(ByVal sender As Object, ByVal e As System.EventArgs) Handles form1.Load
Dim row As TableRow
Dim col As TableCell
If (Page.IsPostBack = False) Then
Label2.Text = "aaa"
row = New TableRow
col = New TableCell : col.Text = "行0:列0" : row.Cells.Add(col) : col = Nothing
col = New TableCell : col.Text = "行0:列1" : row.Cells.Add(col) : col = Nothing
Table1.Rows.Add(row)
row = New TableRow
col = New TableCell : col.Text = "行0:列0" : row.Cells.Add(col) : col = Nothing
col = New TableCell : col.Text = "行0:列1" : row.Cells.Add(col) : col = Nothing
Table1.Rows.Add(row)
End If
End Sub
Protected Sub Button1_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles Button1.Click
Label1.Text = "Rows.Count" & Table1.Rows.Count
End Sub
End Class
ボタンを押すと、
Label2の "aaa" は保持されていて
Table1が保持されないのはなぜなのでしょうか?
Table1 の内容を保持させたいのですが
その場合、どのようにすればよいのでしょうか
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
Label2のデータはViewStateから読み込んでいるため表示されるのだと思います
それに対して Table1のセルはViewStateに保存されているRowsコレクションが無い(または単一セル)のため表示されない様に見えているのではないでしょうか
それと Label2は aspxファイルで定義されているのでViewStateにデータを保存することが可能です
しかし Table1のセルはaspxファイル内で定義されていないのでViewStateにデータを保存することが出来ません
<asp:xxx />タグが無い
PreRender(またはLoad)イベントなどで描画内容を毎回実行しないといいけないと思います
ページレベルの変数として TableRowやTableCellの配列を準備して
これをTable1に追加するようにしても同じ現象になります
Webアプリケーションの場合
変数の寿命がページが作成されて表示しきるまでしか存在しないからです
ポストバックされた時点では前回作成したオブジェクトは前回表示し終わった時点で破棄されているので覚えていません
これではページ上に作成したコントロールなどの状態が分からなくなってしまうので VIEWSTATEといったHIDDENコントロールで記憶しておくのです
コントロールのEnableViewStateプロパティが『True』が標準になっているのはこのためです
ためしに Label2のEnableViewStateを『False』に設定してボタンを押してみてください
『aaa』では無くデザイン時に設定した内容になると思います
回答ありがとうございます
文面を読んで、たしかに、もっともな話だと思いました。
でも、結局遣りたい事をするために
Label1.txt に 自前でHTMLの Tableタグを記述して解決しました
なんか、面倒くさい話ですね
それでは失礼します。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) VBA 別ブックからの転記の高速化について VBA 別ブックからの転記の高速化についてご教授下さい。 19 2022/07/26 13:07
- Excel(エクセル) Excel 、この式はどのように解釈すればいいのでしょうか 4 2023/02/03 08:53
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Visual Basic(VBA) VBAで質問ですが、皆さんはどの様に導き出しているのでしょうか? 6 2022/05/03 21:53
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- Excel(エクセル) マクロで列を加えたら上手くいかなくなりました。 2 2022/05/23 17:59
- Visual Basic(VBA) Excel VBA キーワードから列を取得して、さらに空欄行を非表示にする 3 2022/10/21 22:49
- Visual Basic(VBA) 【VBA】特定のワードが入っている行全体を塗りつぶしたい 4 2022/04/20 15:22
- その他(プログラミング・Web制作) seleniumbasic chrome操作について 1 2023/03/29 15:40
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
C#,vb.netで業務用アプリ開発と...
-
ExcelVBAのコントロールの種類...
-
C#で角が丸いテキストボックス
-
Excel VBA で Richtextboxを使...
-
カメラスクロールするのを動画...
-
ACCESS2010のVBAでフォーム内ク...
-
(VBA)スピンボタンの大量...
-
エクセル・VBA CheckBoxのオブ...
-
winndws セキュリティ
-
フォーカスの枠線を太くしたい
-
PDF起動時のナビゲーションパネ...
-
どれか1つでもチェックされて...
-
VBAのフォームでTextBoxがいっ...
-
ユーザーフォームで動的(Me.Con...
-
wsock32.dllによるconnectのtim...
-
ASP.NET(C#) DataGridのヘッダ...
-
IpadでZoomの音声を録音できる?
-
モニター出力制御
-
EXCELでactivexコントロールを...
-
With~EndWithの省略部分と引数...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
カメラスクロールするのを動画...
-
エクセル・VBA CheckBoxのオブ...
-
vb.netで画面のコントロールId...
-
EXCELでactivexコントロールを...
-
ExcelVBAでListViewが使用できない
-
(VBA)スピンボタンの大量...
-
エクセルVBAでオプションボタン...
-
C#で角が丸いテキストボックス
-
ユーザーフォームで動的(Me.Con...
-
アクセス特有の書き方?
-
間違えて配置してしまったコン...
-
コンボボックスの文字によるif...
-
VBAのエラーについて、”実行時...
-
変数をコントロール型で使用す...
-
chr関数の呼び出しで「プロ...
-
With~EndWithの省略部分と引数...
-
C#で自分のウインド・ハンド...
-
excelのリストボックスで選択し...
-
'ckbl' コントロールは作成され...
-
フォーム上の現在アクティブな...
おすすめ情報