お世話になります。
AccessのVBAはどの分類が適切なのかが分からないのでこちらに投稿させていただきます。
modalフォームAから戻り値を返すdialogフォームB(カレンダーコントロールから日付を取得)を呼出したいのですが、フォームBからフォームAに戻ってきたときにAccess自体が固まってしまします。(フォームAがアクティブになりません。)
VB6では同様な仕組みで問題なく動作しているのですが、解決策はありますでしょうか?
また、modalプロパティ指定時になにか他のプロパティも設定する必要がありますでしょうか?
よろしくお願いします。
No.1ベストアンサー
- 回答日時:
Acc2000で
フォームAの開くときのイベントで
me.modal = true を指定し
フォームBを開く際に
DoCmd.openform "フォームB",,,,,acDialog
フォームBを閉じるときに
DoCmd.close
としてやってみたら普通に動きましたけれど、
何か違うことをしておられるのでしょうか?
この回答への補足
全ての画面で行ないたいので、Formオブジェクトをクラスモジュールで受取り、その中でModal設定しております。
ご指摘の通り、個々のフォームにて設定してできました。
VB6だと上記方法で設定可能なのですが、AccessはNGなのでしょうか?
No.2
- 回答日時:
何かのバグかも知れません。
ともかく、全てのコードを示しておきます。
**************
カレンダーを開く
**************
Private Sub コマンドカレンダー_Click()
On Error Resume Next
Me.Modal = True
DoCmd.OpenForm "カレンダー", , , , , acDialog, "日報,日付"
End Sub
**************
カレンダーフォーム
**************
・テキストボックス[日付]を配置。
Option Compare Database
Option Explicit
Private Sub Calendar0_Click()
Me.日付 = Me.Calendar0.Value
End Sub
Private Sub Form_Close()
Forms(CutStr(Me.OpenArgs, ",", 1)).Controls(CutStr(Me.OpenArgs, ",", 2)) = Me.日付
End Sub
Private Sub Form_Load()
Me.日付 = Me.Calendar0.Value
End Sub
**************
共通標準ライブラリー
**************
Public Function CutStr(ByVal Text As String, _
ByVal Separator As String, _
ByVal N As Integer) As String
Dim strDatas() As String
strDatas = Split("" & Separator & Text, Separator, , 0)
CutStr = strDatas(N * Abs((N <= UBound(strDatas))))
End Function
※一回、全ての関連するプロシージャを消して書き直して見て下さい。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
誕生日にもらった意外なもの
みなさんがもらった誕生日プレゼントで面白いものがあったらぜひ教えてください!
-
フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
あなたが普段思っている「これまだ誰も言ってなかったけど共感されるだろうな」というあるあるを教えてください
-
映画のエンドロール観る派?観ない派?
映画が終わった後、すぐに席を立って帰る方もちらほら見かけます。皆さんはエンドロールの最後まで観ていきますか?
-
海外旅行から帰ってきたら、まず何を食べる?
帰国して1番食べたくなるもの、食べたくなるだろうなと思うもの、皆さんはありますか?
-
天使と悪魔選手権
悪魔がこんなささやきをしていたら、天使のあなたはなんと言って止めますか?
-
日付型のフィールドに空白を入れる方法を教えてください
その他(データベース)
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ユーザーフォームを表示中にシ...
-
VBでフォームのイメージを印...
-
VBAでユーザーフォームを再表示...
-
コントロールの存在確認
-
C#で起動時のフォームを非表示...
-
Access VBA コントロールの参照...
-
指定の動作中ユーザーフォーム...
-
Excelにて、ユーザーフォームで...
-
Excelのユーザーフォームのテキ...
-
ExcelVBAのユーザーフォームの...
-
VB.NETでフォームロード中のエ...
-
最小化最大化のボタンの表示を...
-
(Excel+VBA)ユーザーフォームの...
-
VB6 自分自身のフォームが...
-
任意のフォームが表示されてい...
-
なぜRecalcではだめなのか?
-
Form_Load と Form_Activate の...
-
ユーザーフォーム上に現在日時...
-
C#で3つのプログラムができま...
-
[VB6] フォームを閉じる方法に...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ユーザーフォームを表示中にシ...
-
ExcelVBAのユーザーフォームの...
-
ユーザーフォームのテキストボ...
-
エクセルVBAのフォームを最...
-
クリックイベントなのに、2回ク...
-
VBAでユーザーフォームを再表示...
-
Form_Load と Form_Activate の...
-
Microsoft Formsの「個人情報や...
-
ACCESSのフォーム、開くんです...
-
'ユーザーフォーム右上隅の[×...
-
フォームウィンドウを最前面に...
-
Hideについて(.NET)
-
モーダルフォームとモードレス...
-
ユーザーフォーム上に現在日時...
-
MSGBOXのフォント大きさ変更
-
Excelにて、ユーザーフォームで...
-
コントロールの存在確認
-
ユーザーフォームのラベルに時...
-
VBA(エクセル)のユーザー...
-
エクセルVBA フォーム上でOnkey...
おすすめ情報