No.2ベストアンサー
- 回答日時:
親フォームからサブフォーム、或いは逆でも、イベントの取得は可能です。
但し、手続き(?)が複雑なことなどから、意図した動作をさせるには、
かなり苦労するかもしれません(汗)
ともあれ、とりあえず簡単なサンプルを提示してみます。
・子フォームのレコード移動時イベントを、親フォームで取得
・親フォームのコマンドボタンのクリック時イベントを、子フォームで取得
【構成】
・親フォームに設置したコンボボックスの名前: 起動
・コントロールとしてのサブフォームの名: SF1
※レコード移動時イベントを発生させる関係上、子側のレコードソースには
適当なテーブル/クエリを指定して下さい。
【コード】
<親側>
'フォームのモジュールレベル(全てのSub/Functionよりも前の領域)で、
'イベントを取得したいオブジェクトを参照する変数を宣言
'★「WithEvents」により、イベント取得が可能になります★
Private WithEvents Frm As Form
'開く時イベント
Private Sub Form_Open(Cancel As Integer)
'変数に子フォームを設定
Set Frm = Me!SF1.Form
End Sub
'閉じる時イベント
Private Sub Form_Close()
'念のため、明示的に変数を解放
Set Frm = Nothing
End Sub
'サブフォームのレコード移動時イベントを受けて行う処理
'★「Sub」の後は「Form_」でなく「Frm」(=変数名)なので注意★
Private Sub Frm_Current()
MsgBox "子側でレコード移動がありました"
End Sub
'自身に設置したコマンドボタンのクリック時
Private Sub 起動_Click()
MsgBox "親側でボタンクリック"
End Sub
<子側>
'親と同様にモジュールレベルで変数を宣言
Private WithEvents Btn As CommandButton
'開く時
Private Sub Form_Open(Cancel As Integer)
Set Btn = Me.Parent!起動
End Sub
'閉じる時
Private Sub Form_Close()
Set Btn = Nothing
End Sub
'レコード移動時
Private Sub Form_Current()
MsgBox "子側でレコード移動"
End Sub
'親側のコマンドボタンのクリックを受けて行う処理
Private Sub Btn_Click()
MsgBox "親側でボタンがクリックされました"
End Sub
・・・以上です。
これで、子側のレコード移動で、親/子の双方のMsgBoxが表示
されることを確認したら、これをベースに、実際に行いたい処理コードを
追加していってみてください。
なお、「Private Sub Btn_Click()」などは、全て手入力する必要が
あります(「Sub 」の後は、「変数名」+「_」(アンダーバー)+「イベント名」)。
また、マウスボタンクリック時のように、引数を持つイベントの場合は、
それらも同様に記述しないと、コンパイルエラーになるのでご注意下さい。
◆参考(別手法)◆
禁じ手的ではありますが(汗)、「親側から子側のイベント取得」とは逆に、
「子側から親側の各イベント時の処理の呼び出し」も可能です。
例えば、子側のレコード移動時に、親側の『起動』ボタンのクリック時
の処理を実行するには、以下のようにします:
<親側>
同ボタンのクリック時イベントの「Private」を「Public」に変更
<子側>
以下のような構文で、同ボタンのクリック時の処理を子側のレコード
移動時に呼び出せます:
Private Sub Form_Current()
Call Me.Parent.起動_Click
End Sub
※親側からの呼び出しは以下のようにします:
(子側のレコード移動時イベントの処理を実行する場合)
SF1.Form.Form_Current
または
Me.SF1.Form.Form_Current
ご返事ありがとうございます。
とてもわかりやすいご回答ありがとうございます。このサンプルを元に自分でも色々試してみようと思います。
ありがとうございました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- その他(プログラミング・Web制作) google formsを使ったタスク依頼フォーム作成におけるご相談 1 2023/06/22 15:55
- Visual Basic(VBA) VB.net フォーム 親子 1 2022/07/04 19:00
- Access(アクセス) アクセス 意図せずサブプロシージャを移動してしまうのを止めたい 1 2022/09/02 09:19
- その他(データベース) Accessフォームからパラメーターで表示したレコードを指定のExcelのセルへ転送する方法について 2 2022/08/22 18:04
- Access(アクセス) accessについて(超初心者です) 1 2023/02/11 11:18
- 楽器・演奏 ★この考え方 どう思われますかぁ? 5 2023/06/08 16:44
- Access(アクセス) アクセスの更新クエリでカレントレコードのみ更新したい 1 2022/06/02 23:32
- Access(アクセス) Access 登録ボタンからサブフォームの更新 1 2022/07/22 10:23
- Access(アクセス) Accessでセレクタをダブルクリックで別フォームで詳細表示 3 2022/12/20 10:36
- PHP php 確認表示画面で値をSESSIONから取り出す理由の解釈は正しいでしょうか? 1 2023/06/09 17:39
このQ&Aを見た人はこんなQ&Aも見ています
-
これまでで一番「情けなかったとき」はいつですか?
これまでの人生で一番「情けない」と感じていたときはいつですか? そこからどう変化していきましたか?
-
秘密基地、どこに作った?
小さい頃、1度は誰もが作ったであろう秘密基地。 大人の今だからこそ言える、あなたの秘密基地の場所を教えてください!
-
「覚え間違い」を教えてください!
私はかなり長いこと「大団円」ということばを、たくさんの団員が祝ってくれるイメージで「大円団」だと間違えて覚えていました。
-
プリン+醤油=ウニみたいな組み合わせメニューを教えて!
プリンと醤油を一緒に食べると「ウニ」の味がする! というような意外な組み合わせから、新しい味になる食べ物って色々ありますよね。 あなたがこれまでに試した「組み合わせメニュー」を教えてください。
-
うちのカレーにはこれが入ってる!って食材ありますか?
カレーって同じルーから作っても、家庭によって入っているものや味が微妙に違っていて面白いですよね! 「我が家のカレーにはこれが入ってるよ!」 という食材や調味料はありますか?
-
Access サブフォームでの選択行の取得
その他(データベース)
-
サブフォームに対してGoToRecordするには?
その他(Microsoft Office)
-
Access2000 サブフォームのRecordSet取得法
Access(アクセス)
-
-
4
Access でレコードセレクタが押されたときのイベントは?
その他(プログラミング・Web制作)
-
5
ACCESS VBAサブフォーム(DATA SHEET)の値の取得方法
Visual Basic(VBA)
-
6
【ACCESS】フォーム名/コントロール名を文字列型変数で指定するには
Access(アクセス)
-
7
サブフォームでのダブルクリックイベント
Access(アクセス)
-
8
SQL文で パラメータが少なすぎます エラー
Access(アクセス)
-
9
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
-
10
Accessでサブフォームのボタンクリックイベントをメインフォームで処理したい。
Access(アクセス)
-
11
access サブフォームにリストを表示させたいが一件しかレコードが表示されない
Access(アクセス)
-
12
Accessのフォームにて、詳細行のボタンを行の内容により、表示/非表
その他(Microsoft Office)
-
13
レコードを保存するコード アクセスvba
その他(Microsoft Office)
-
14
Accessで埋め込んだサブフォーム(データシート形式)でデータ追加ができない
Access(アクセス)
-
15
[Access]帳票フォームにて連続する非連結コントロールに個々の値を入れるには
Access(アクセス)
-
16
フォームを開くときに、コンボボックスの値を選択(アクセスVBA)
Visual Basic(VBA)
-
17
クエリで出来た表にチェックボックスを追加する
その他(Microsoft Office)
-
18
YES/NO型の値
Excel(エクセル)
-
19
フォームの高さを数値で指定したいのですが
Excel(エクセル)
-
20
サブフォームを非表示させる方法を教えて下さい
その他(Microsoft Office)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/22】このサンタクロースは偽物だと気付いた理由とは?
- ・お風呂の温度、何℃にしてますか?
- ・とっておきの「まかない飯」を教えて下さい!
- ・2024年のうちにやっておきたいこと、ここで宣言しませんか?
- ・いけず言葉しりとり
- ・土曜の昼、学校帰りの昼メシの思い出
- ・忘れられない激○○料理
- ・あなたにとってのゴールデンタイムはいつですか?
- ・とっておきの「夜食」教えて下さい
- ・これまでで一番「情けなかったとき」はいつですか?
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Accessでフォームから別フォー...
-
ExcelVBAでフォーム内でブック...
-
VBA リストボックスをダブルク...
-
ExcelVBAでユーザーフォーム内...
-
VBAにてメッセージボックスを最...
-
accessで2つ以上のフォームを起...
-
PDFフォーム内で日付計算したい...
-
【ACCESS2003】サブフォーム名...
-
Googleフォーム・複数人の申し...
-
csvに保存しているデータをURL...
-
リストボックスの選択解除
-
フォーム上の全てのコントロー...
-
VB.net(VB)で、フォームにExcel...
-
dbOpenTableとdbOpenDynaset
-
Access 無操作の場合、自動で閉...
-
ACCESS VBAサブフォーム(DATA S...
-
VBプログラムの終了
-
ACCESS 表形式フォームで1レ...
-
VBのEXEファイルのサイズを小さ...
-
サブフォームの行ごとにコンボ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Googleフォーム・複数人の申し...
-
VBAにてメッセージボックスを最...
-
Accessでフォームから別フォー...
-
ExcelVBAでフォーム内でブック...
-
アクセスVBA フォームのス...
-
VB.net(VB)で、フォームにExcel...
-
サブフォームの新規レコードに...
-
メッセージボックスの背景色
-
Access 無操作の場合、自動で閉...
-
VBA リストボックスをダブルク...
-
accessで2つ以上のフォームを起...
-
VBプログラムの終了
-
リストボックスの選択解除
-
ユーザーフォーム上にアイコン...
-
ToolStripStatusLabelを固定し...
-
サブフォームの行ごとにコンボ...
-
VBAでフォームのスクロールバー...
-
フォーム上の全てのコントロー...
-
サブフォームのイベント取得
-
ディスプレイ解像度より大きな...
おすすめ情報