こんにちは。
標準モジュールからフォームのリストボックスに文字を追加したいんですが、うまくいきません。
まず、button1をクリックすると、共通モジュールのサブルーチンを呼び出します。そして引数"0"を渡すと、Form1のListBox1に"hello"を追加したいのです。
実行させると、エラーはでないのですが、追加されるはずの"hello"がListBox1に追加されません。
たぶん
frm1.ListBox1.Items.Add("hello")
あるいは
Dim frm1 As New Form1()
あたりの宣言の仕方がまずいのだと思うんですが...
どなたか、ご教授よろしくお願いします。
■共通モジュール
Module Module1
Dim frm1 As New Form1()
Sub PC(ByVal PCrecieve As String)
If PCrecieve = "0" Then
frm1.ListBox1.Items.Add("hello")
End If
End Sub
End Module
■フォーム
Public Class Form1
Inherits System.Windows.Forms.Form
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
Call PC("0")
End Sub
End Class
No.3ベストアンサー
- 回答日時:
あまり気にしないでほしい出んけども、
Dim frm1 As New Form1()
としているだけで、
実体の
frm1 = Form1.ActiveForm
を関連付けていないからではないでしょうか?
たびたびすみませんでした。
自身なしです。
Sub PC(ByVal PCrecieve As String)
frm1 = Form1.ActiveForm
If PCrecieve = "0" Then
frm1.ListBox1.Items.Add("hello")
End If
End Sub
何度もありがとうございます。
確かにfrm1 = Form1.ActiveFormを加えたらリストボックスに"hello"が表示されるようになりました。しかし実体の関連付けというのは、必ずしなければならないんでしょうか?オブジェクト指向だから?
"ActiveForm"ってVB.netの本4冊持っているんですが、その内一冊にしかでてないんですよ。ここで質問しなかったら永久にわからなかったかもしれません。
ありがとうございました。
No.2
- 回答日時:
できましたのでサンプルですが、ご報告です。
Public Class Form1
Inherits System.Windows.Forms.Form
Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
Dim dd As Module1
dd = New Module1
dd.test()
End Sub
End Class
Class Module1
Sub test()
Dim frm As New Form1
frm = Form.ActiveForm
frm.Button1.Text = "hello"
MsgBox("hhh")
End Sub
End Class
あまり、よく理解できていないですが、、、、
No.1
- 回答日時:
Formにコマンドボタン1つとリストボックスを1つ貼りつけました。
Project-Form1(コード)
Private Sub Command1_Click()
pc ("0")
End Sub
Project-Module1(コード)
Sub pc(ByVal PCarg As String)
If PCarg = "0" Then
Form1.List1.AddItem "Hello"
End If
End Sub
でフォームを実行-開始し、コマンドボタンをクリックするごとに、リストボックスにHelloが現れましたが。
この回答への補足
はい。このソースでできました。
書くのを忘れていましたが、VB.netで実行したいのです。回答された、このソースだと確かにVB6.0では動くのですが、VB.netだと「オブジェクト参照」に関してエラーになると思います。どなたかその辺りに詳しい人はいらっしゃらないでしょうか?
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 【Excel VBA】自動メール送信の機能追加 5 2022/09/29 12:53
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る バッチからEXEの結果を受け取りたいのですが、 下記のバッ 1 2023/07/04 15:13
- Visual Basic(VBA) batからexeを実行し戻り値を受け取る EXEの実行内容の結果によって、戻り値を0か1かで返したい 1 2023/07/04 16:40
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- Visual Basic(VBA) いつもお世話になっております、VBAで教えて頂きたいのですが 2 2022/05/05 22:20
- Visual Basic(VBA) VBA This Workbookモジュールを別ファイルにコピーする方法 1 2022/09/14 01:51
- Visual Basic(VBA) VBAで質問ですが、皆さんはどの様に導き出しているのでしょうか? 6 2022/05/03 21:53
- Visual Basic(VBA) EXCEL VBAにて動的にCheckBOXを複数作成し、同BOXにイベントを追加したい 1 2023/03/16 07:05
- Visual Basic(VBA) ユーザーフォーム「frm_基本❶」を立ち上げると新規で入力する行数を右下のNoとして表示しています。 1 2023/03/16 19:02
- Visual Basic(VBA) ①ExcelVBAでカレンダーを作り、別のユザーフォームで日付を入力したいのですがエラーになります。 1 2023/02/17 18:39
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教えるわが家の防犯対策術!
ホームセキュリティのプロが、家庭の防犯対策を真剣に考える 2組のご夫婦へ実際の防犯対策術をご紹介!どうすれば家と家族を守れるのかを教えます!
-
フォームのテキストボックスなどの変数名を標準モジュールから参照は可能か?
Visual Basic(VBA)
-
VBAです。ユーザーフォームの表示させ、標準モジュールを読み込ませる方法について
Visual Basic(VBA)
-
Excel VBAで、ユーザーフォームの値を、モジュールで使用したい。
Visual Basic(VBA)
-
-
4
EXCEL VBAのユーザーフォームに引数を渡す方法について
Excel(エクセル)
-
5
UserForm1.Showでエラーになります。
工学
-
6
VBのフォームモジュールと標準モジュールの使い分け
Visual Basic(VBA)
-
7
VBAでユーザーフォームを再表示させたい。
Excel(エクセル)
-
8
【ACCESS】フォーム名/コントロール名を文字列型変数で指定するには
Access(アクセス)
-
9
VBAで保存しないで閉じると空のBookが残る
Excel(エクセル)
-
10
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
11
フォントの大きさ
Visual Basic(VBA)
-
12
On ErrorでエラーNoが0
Visual Basic(VBA)
-
13
エクセルへのデータの貼付時に書式が反映されない!
Visual Basic(VBA)
-
14
エクセルVBA オプションボタンのチェックを外したい
Excel(エクセル)
-
15
テキストボックスの番号を使ったFor~Next文について
Visual Basic(VBA)
-
16
Access-VBAのPublic変数について =基本的な事です=
Visual Basic(VBA)
-
17
IF文に時間(何時から何時まで)の条件文を付けたい
Word(ワード)
-
18
テキストボックスのvalueとtextの違い
Visual Basic(VBA)
-
19
vba userFormのSubを標準モジュールから呼び出す方法を教えてください
Visual Basic(VBA)
-
20
Form_Load と Form_Activate のタイミング
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ユーザーフォームを表示中にシ...
-
Form_Load と Form_Activate の...
-
エクセルVBAのフォームを最...
-
VBAでユーザーフォームを再表示...
-
ACCESSのフォーム、開くんです...
-
ユーザーフォームのテキストボ...
-
クリックイベントなのに、2回ク...
-
Hideについて(.NET)
-
Excelにて、ユーザーフォームで...
-
Microsoft Formsの「個人情報や...
-
MSGBOXのフォント大きさ変更
-
ExcelVBAのユーザーフォームの...
-
コントロールの存在確認
-
モーダルフォームとモードレス...
-
ユーザーフォーム上に現在日時...
-
【VBAユーザーフォームで閉じる...
-
ユーザフォームの印刷
-
vb2008にてDefaultCellStyleが...
-
フォームウィンドウを最前面に...
-
keypressイベントでEnterキー(a...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ユーザーフォームを表示中にシ...
-
ExcelVBAのユーザーフォームの...
-
ユーザーフォームのテキストボ...
-
クリックイベントなのに、2回ク...
-
MSGBOXのフォント大きさ変更
-
VBAでユーザーフォームを再表示...
-
Hideについて(.NET)
-
Form_Load と Form_Activate の...
-
モーダルフォームとモードレス...
-
コントロールの存在確認
-
ユーザーフォーム上に現在日時...
-
【VBAユーザーフォームで閉じる...
-
エクセルVBAのフォームを最...
-
ACCESSのフォーム、開くんです...
-
Microsoft Formsの「個人情報や...
-
VBA(エクセル)のユーザー...
-
フォームウィンドウを最前面に...
-
ユーザーフォームのラベルに時...
-
'ユーザーフォーム右上隅の[×...
-
Excelにて、ユーザーフォームで...
おすすめ情報