1つのForm上のコマンドボタンで別のFormを表示、そこで変数に値を入れ、そのFormを閉じ、元のFormでその変数を使いたいのですが、どうもうまくいきません。
実施したやり方は、一方のFormの宣言領域で、”Public abc As String”を宣言、両方のFormの(変数に値を入れた方と変数を使う方の)プロシージャーの宣言では引数として(abc As String)と記述しました。
因みに、両プロシージャーともイベントプロシージャーです。何か基本的なことができていないのだとは思いますが、どなたか教えていただけませんか?よろしくお願いします。
No.5ベストアンサー
- 回答日時:
すでに何件か回答があがっていますので、少し変わった方法をご参考までに。
あまり使われませんが、Formにはtagというプロパティがあります。
これは「文字列形式であれば何でも格納できる」という、上手く使えば便利なプロパティです。
FormAからFormBを呼び出し、FormBで変更した値をFormA.tagにセットします。
ここでFormBをUnloadしてもFormA.tagの値は影響を受けないので自由に使えます。
複数の値を呼び出し元に戻してやる場合に、区切り文字(カンマなど)で連結した文字列をtagに格納し、呼び出し元で区切り文字でsplitして、複数の値を受け渡すという手法をよく使っています。
回答ありがとうございます。
確かに・・慣れれば非常に便利な気がします。
いちいちPublicで変数を宣言しなくてよいということですね。
それから、回答下さった皆さんにも、改めてお礼を言わせて頂きます。無事、解決しました。
No.4
- 回答日時:
Form内でPublic宣言した変数は、そのFormが生きている間だけ有効です。
UnloadしたFormの変数にはアクセスできません。
Form1からForm2を開いて、Form2を閉じたときにForm2の変数をチェックするときに私が良く使う方法は、
[Form1]
Form1.Show vbModal
myValue = Form2.myValue
Unload Form2
[Form2]
Public myValue as Long
Private Sub Button1_Click()
Me.Hide
End Sub
つまり、Formを閉じるときにいきなりUnloadせずにHideしておき、
Formを呼び出した側がデータを取得後にUnloadするようにします。
回答ありがとうございます。
そもそもわたしは非表示にする方法しか知りませんでした。なるほど大変参考になりました。
ところで、FormをUnloadするのと非表示とするのでは、やはり動作の軽さが違うのでしょうか?
No.3
- 回答日時:
フォームが開いている状態で
フォーム内でpublicで宣言してあれば
別フォームからでも「フォーム名.変数名」で参照
できますよ。
自分は標準モジュールでプロジェクト全体で宣言を
するのはあまり好きではないので(モジュール結合度の問題からして)
フォーム間でのデータ明け渡しはこれを使っています。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- JavaScript セレクトを全て選択されていないと、文字によるエラーメッセージを表示させるコードを調べています 2 2023/06/22 15:48
- PHP PHPでCookieを使った訪問回数について 1 2023/05/28 14:10
- JavaScript javascriptで入力フォームが空欄の時にアラートによるエラーを出すコードを書いています。 2 2023/06/13 17:58
- WordPress(ワードプレス) Wordpress プラグイン Mail Form 7 のファイル添付の表示が切れてしまう 1 2022/03/24 09:05
- IT・エンジニアリング ドメイン駆動設計の値オブジェクトについて質問 1 2023/05/13 02:50
- HTML・CSS ボタンをクリックした時に、入力フォームのすぐ下部に、「入力欄が空白です」というテキストメッセージが表 1 2022/04/27 16:25
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- JavaScript javascriptのちょっとした動作不良(原因は突き止めたのですが) 1 2023/06/15 19:58
- PHP PHPで画像の渡しが上手く行きません。 1 2023/02/02 09:39
- PHP 重複を防ぐ記述について教えて下さい。 3 2023/04/03 14:35
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
ExcelVBAでテキストボックスの表示形式を小数点第二位まで表示する方法
Visual Basic(VBA)
-
EXCEL VBAのユーザーフォームに引数を渡す方法について
Excel(エクセル)
-
Accessで、フォームからフォームへ値を引き継ぐやり方
Access(アクセス)
-
-
4
ユーザーフォームに入力したデータを保持する方法
Visual Basic(VBA)
-
5
他のフォームから別のフォームのサブルーチンを呼び出す
Visual Basic(VBA)
-
6
VBA:ユーザーフォームのマルチページに色を付けたい。
Word(ワード)
-
7
Excel VBAで、ユーザーフォームの値を、モジュールで使用したい。
Visual Basic(VBA)
-
8
どこにもフォーカスを当てたくない
Access(アクセス)
-
9
VBAで別モジュールへの変数の受け渡し方法
Visual Basic(VBA)
-
10
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
11
エクセルのラベルの値(文字列)を垂直方向で中央揃えにするには?
Excel(エクセル)
-
12
エクセルVBAでUserFormを起動した時
Excel(エクセル)
-
13
VBAでユーザーフォームの表示を確認
Visual Basic(VBA)
-
14
メッセージボックスに表示する文字を大きくしたい
Excel(エクセル)
-
15
ユーザーフォームのテキストボックスに前回入力した値を表示する Excel
Visual Basic(VBA)
-
16
Excelvbaでフォーム間での変数引き継ぎについて
Visual Basic(VBA)
-
17
VBA public変数はどのようなことをしたら解放されますか?
Visual Basic(VBA)
-
18
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
19
Access サブフォームでの選択行の取得
その他(データベース)
-
20
フォームのテキストボックスの値をコピーしたい
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA モジュールで共通に使う変...
-
'Range'メソッドは失敗しました
-
VBAで別モジュールへの変数の受...
-
Excel VBAでリンク切れをチェッ...
-
プラグイン、ライブラリ、コン...
-
【vba】フォームに書いてあ...
-
印刷後メッセージボックスを表...
-
VBA This Workbookモジュール...
-
モジュールからフォームのボタ...
-
コンボボックスの変更に応じて...
-
VBAで旧字体を異字体に一括で変...
-
VBでグローバル変数を宣言するには
-
VHDLにおける「generic」について
-
Excelシート内セル記述の違いに...
-
エクセルVBAで標準モジュー...
-
エクセルVBAでシートモジュール...
-
ユーザーフォームに最小化・最...
-
acwzlibとは?
-
pythonでファイル移動できません。
-
モジュールフローとは?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Excel VBAでリンク切れをチェッ...
-
ユーザー定義関数に#NAME?が返...
-
VBAで別モジュールへの変数の受...
-
エクセルVBAでシートモジュール...
-
VBAで旧字体を異字体に一括で変...
-
VBでグローバル変数を宣言するには
-
'Range'メソッドは失敗しました
-
Excel VBA 『Call』で呼び出す...
-
グラフのX,Y座標を取得したい
-
Access VBA標準モジュールにつ...
-
本当にPublicな変数(配列で)
-
Excel VBAで、ユーザーフォーム...
-
VBA This Workbookモジュール...
-
モジュールの最大数はいくつな...
-
【vba】フォームに書いてあ...
-
モジュールとは何ですか
-
モジュールとクラスの違いって...
-
VBA モジュールで共通に使う変...
-
関数の引数にクラスを使いたい
-
Form間の値の渡し方
おすすめ情報