初心者です。VB2010においてわからないことがあるので教えていただきたいです。よろしくお願いします。
メイン画面でデータ表示、サブ画面で条件を指定し、サブ画面において決定ボタンを押したらメイン画面のデータの絞り込みを行う。というような仕様のプログラムを組んでいるのですが、数点教えていただきたいです。
1、サブ画面のボタンが押されたら(Button1とする)、メイン画面を更新する、という動作を実現させたいのですが、どのように記述したらよいでしょうか?(メイン側に)。
サブ側は決定ボタンを押した時点で画面が閉じるように設定してあります。
2、サブ画面で決定ボタンを押したときに、メイン画面からその時点でのサブ側の変数を参照したいのですが、どのように参照したらいいでしょうか?(例えばサブ側のflag(integer型)の値を参照する、など)
以上です。申し訳ないですがよろしくお願いします。
A 回答 (4件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
※Windows Forms Application を想定しています。
WPF であれば,ほぼ変わらない想定でいけると思います。基本的には,
・やりとりするデータはクラスにまとめておき,アクセス用のプロパティを用意しておく
_・データ表示ウィンドウ側で生成し,条件指定ウィンドウ側にコンストラクタやプロパティを通じてインスタンスを渡す
_・条件指定ウィンドウ側では渡されたインスタンスとコントロールをデータバインドするか,イベントを通じてデータを同期させる
・データが決定された,または入力が取り消されたことは,メソッド呼び出しとイベントの機構を通じてやりとりする
_・条件指定ウィンドウ側からはメソッドを呼び出すことでデータクラスに通知する
_・データクラスは専用のイベントを発生させる
_・データ表示ウィンドウ側はデータクラスのイベントのハンドラを通じて知る
となります。
まぁ,モーダルウィンドウとして条件指定ウィンドウを表示しているのであれば,
ShowDialogの戻り値を利用してデータが決定されたか取り消されたかを通知してもよいと思います。
で,ここまで疎にする必要が無い場合,条件指定ウィンドウに,アクセス用のプロパティを実装します。
上記のデータクラスを条件指定ウィンドウと一緒にしてしまった感じになります。
間違っても,条件指定ウィンドウのフィールドやコントロールにデータ表示ウィンドウから直接アクセスするような構造にしてはいけません。
# 慣れた人がわかった上でやるのは構わないけれども,自称でも初心者であるならば,基本に忠実であるべきかと。
1.に関しては,全部データバインドして,ボタンを押したタイミングでモデルのメソッドを呼び出すなりして,モデル全体に更新をかけてしまえば解決します。
ListViewやTreeViewなどのバインド不可のコントロールが入っている場合やデータバインドを利用していない場合などは,
イベントをトリガにコントロールのデータを表示することになります。
先に書いた通り,ShowDialogの戻り値を使ってイベントのトリガの代わりにすることも可能です。
2.に関しては,そもそも参照対象の「サブ側の変数」をデータクラスに追い出したので,必要な値はデータクラスから取得できます。
No.2
- 回答日時:
もう少し、自分で調べる癖をつけたほうがいいですよ。
「VB.NET クラスプログラミング」、「変数のスコープ」、「フォーム操作」、「配列の変数の受け渡し」
このあたりは自習書やGoogle で調べればわかります。
http://hanatyan.sakura.ne.jp/dotnet/Sample.htm
http://www.atmarkit.co.jp/fdotnet/dotnettips/ind …
No.3
- 回答日時:
もう少し、自分で調べる癖をつけたほうがいいですよ。
「VB.NET クラスプログラミング」、「変数のスコープ」、「フォーム操作」、「配列の変数の受け渡し」
このあたりは自習書やGoogle で調べればわかります。
http://hanatyan.sakura.ne.jp/dotnet/Sample.htm
http://www.atmarkit.co.jp/fdotnet/dotnettips/ind …
http://dobon.net/vb/dotnet/vb6/property.html
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
ロボットの住む世界で流行ってる罰ゲームとは?
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
Visual Basic.NETの、Form 間での引数の引渡し方法を教えてください。
Visual Basic(VBA)
-
Hideについて(.NET)
Visual Basic(VBA)
-
VB.NETでコンボボックスの1行目を空白にしたい
Visual Basic(VBA)
-
-
4
【VB6.0】 あるフォームから他のフォームへ値を受け渡したい
Visual Basic(VBA)
-
5
VB.NET2005 TextBox 高さ(Height) 変更
Visual Basic(VBA)
-
6
VB.NETでのイベントの途中終了
Visual Basic(VBA)
-
7
Integer変数をカラにしたいのですが
Visual Basic(VBA)
-
8
VB.NETで小数点以下の桁数を取得したい
その他(ソフトウェア)
-
9
VB.NETで DataRow()を利用して、値からコードを取得したい。
Visual Basic(VBA)
-
10
VB.NET Excelを読み込んでDataTableに格納し、DBにデータをINSERTする
Microsoft ASP
-
11
VB.NETでボタンのクリックイベントハンドラが2回実行される
Visual Basic(VBA)
-
12
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
13
VB6で、長い時間かかる処理実行中の表示の工夫について
Visual Basic(VBA)
-
14
テキストボックスの中身をリセット(クリア)したい
Visual Basic(VBA)
-
15
テキストボックスかラベル上の表示を縦に中央揃えしたい
Visual Basic(VBA)
-
16
Form_Load と Form_Activate のタイミング
Visual Basic(VBA)
-
17
データグリッドビューの一番最初の行に列を追加したい
Visual Basic(VBA)
-
18
VB.NETでフォーム上にExcelのような表を表示する方法
Visual Basic(VBA)
-
19
TextBoxに半角数字のみの入力しかできないようにしたい
Visual Basic(VBA)
-
20
別フォームから戻ったときのイベント
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
教えて下さい
-
メモ帳(テキストデータ)をExc...
-
配列でデータが入っている要素...
-
ActiveReportについて
-
シーケンサにパソコンからアク...
-
ACCESSからEXCELに出力する際、...
-
<VB>String→Object
-
PLSQLで文字列置換
-
エクセルで2つの時系列のデー...
-
ウィンドウ枠の固定を行の2箇所...
-
クレジットカードの磁気データ...
-
VBAで「"」[']をエスケープする...
-
リストの高速検索アルゴリズム
-
この行は既に別のテーブルに属...
-
関数を教えていただきたくおね...
-
VBA 空白セルを削除ではない方...
-
[C言語] コメント文字列を無視...
-
シリアル通信プログラム(受信...
-
ACCESS VBA インデックスが有効...
-
10週間以内のデータ
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
教えて下さい
-
【エクセル】測定時間がバラバ...
-
配列でデータが入っている要素...
-
VBA 円グラフ 特定条件に一致し...
-
メモ帳(テキストデータ)をExc...
-
EXCELVBAでSQLserverからデータ...
-
VBA 空白セルを削除ではない方...
-
S9タイプからXタイプにデータ...
-
ブレーカー落ちで壊れたりしな...
-
Accessで該当データにフラグを...
-
多量のSUMIF式を軽くしたい
-
エクセルで2つの時系列のデー...
-
VBAを使ってOutlookメール本文...
-
特定のデータの抽出方法を教え...
-
この行は既に別のテーブルに属...
-
カンマからスラッシュに
-
VBAでシートからコンボボックス...
-
GridViewの行の一部を複数行にする
-
ユーザーフォームのテキストボ...
-
<VB>String→Object
おすすめ情報