ユーザーフォーム入門
コントロールの追加(コマンドボタン)

Excelマクロのユーザーフォームの基礎、エクセルVBAの入門解説
公開日:2013年5月以前 最終更新日:2019-12-15

第3回.コントロールの追加(コマンドボタン)


ユーザーフォーム入門として基礎から解説します。
何もないフォームでは何もできませんので、とりあえず部品を配置しましょう。
この部品をコントロールと呼びます。


ツールボックス

ツールボックスには、使えるコントロールが並んでいます。

VBA マクロ ユーザーフォーム

このツールボックスにあるアイコンが使えるコントロールになります。
ここには、他のコントロールを追加する事もできますが、それは後々。

VBA マクロ ユーザーフォーム これは、配置されているコントロールを選択する場合に使います。

マウスをアイコンの上に置くと、ポップアップのメッセージが表示されますので、
それぞれのアイコンの意味は分かるようになっています。

VBA マクロ ユーザーフォーム

コマンドボタンを配置

では、まずはコマンドボタンを配置してみましょう。

VBA マクロ ユーザーフォーム

アイコンは、これです。
これをクリックして、フォーム上でドラッグしてサイズを決定します。

VBA マクロ ユーザーフォーム

このような感じです。
このボタンは、フォームを閉じるボタンにします。

プロパティの変更

プロパティで、オブジェクト名とCaptionを変更しましょう。
オブジェクト名:btnCancel
Caption:閉じる


VBA マクロ ユーザーフォーム

このように指定します。
そうするとすると、

VBA マクロ ユーザーフォーム

このように、ボタンの名称も変更されます。

次は、このボタンをダブルクリックするか、
右クリックで、「コードの表示」

VBA マクロ ユーザーフォーム

VBA マクロ ユーザーフォーム

このように、そのボタンのイベントが自動で追加されます。

ただし、追加されるイベントは、コントロールの種類によって、
デフォルトのイベントが追加されますので、適宜変更が必要になる場合があります。
コマンドボタンの場合は、Clickイベントが追加されます。
コマンドボタンならほとんどこれで良いですね。
では、このイベントを以下のように書き換えます。

Private Sub btnCancel_Click()
  Unload Me
End Sub

これで、閉じるボタンの完成です。

Unload Me
これは、
Unload frmSample


このように、フォーム名を書いても良く、WEB等でも見かけることがありますが、
フォーム毎に、いちいち変更するのも面倒です。
ここは、Meを指定しましょう。
Meとは自分自身のユーザーフォームを指します。
つまり、Meを指定して自分自信を閉じます

フォームを表示して動作確認

それでは、標準モジュールに既に作成してある、

Sub FormShow()
  frmSample.Show
End Sub

これを実行してみましょう。

VBA マクロ ユーザーフォーム

「閉じる」をクリックして、フォームが閉じられる事を確認して下さい。


今回はここまでです。
次回は、コントロールの位置やサイズの変更方法を詳しく解説します。
ではまた次回お会いしましょう。




同じテーマ「ユーザーフォーム入門」の記事

第1回.ユーザーフォームを挿入
第2回.フォームのプロパティ
第3回.コントロールの追加(コマンドボタン)
第4回.コントロールの位置・サイズ調整
第5回.ラベルの追加
第6回.テキストボックス(TextBox)の追加
第7回.テキストボックス(TextBox)の値をセルへ
第8回.セルの値をテキストボックスへ
第9回.標準モジュールとフォーム間のデータ受け渡しⅠ
第10回.標準モジュールとフォーム間のデータ受け渡しⅡ
第11回.コンボボックス(ComboBox)の追加


新着記事NEW ・・・新着記事一覧を見る

第5章:AI×VBAでつまづかない!トラブルシューティングとAIとの付き合い方 |生成AI活用研究(2025-05-20)
第4章:【事例で学ぶ】AIとVBAでExcel作業を劇的に効率化する! |生成AI活用研究(2025-05-20)
第3章:AIを「自分だけのVBA先生」にする!質問・相談の超実践テクニック|生成AI活用研究(2025-05-19)
第2章 VBAって怖くない!Excelを「言葉で動かす」(超入門)|生成AI活用研究(2025-05-18)
第1章:AIって一体何?あなたのExcel作業をどう変える?(AI超基本)|生成AI活用研究(2025-05-18)
AI時代のExcel革命:AI×VBAで“書かない自動化”超入門|生成AI活用研究(2025-05-17)
Geminiと100本ノック 23本目:シート構成の一致確認|生成AI活用研究(5月16日)
AIが問う出版の未来は淘汰か進化か:AIと書籍の共存の道とは|生成AI活用研究(2025-05-16)
Geminiと100本ノック 22本目:FizzBuzz発展問題|生成AI活用研究(5月15日)
すぐに使える!生成AI プロンプト作成 実践ガイド|生成AI活用研究(2025-05-15)


アクセスランキング ・・・ ランキング一覧を見る

1.最終行の取得(End,Rows.Count)|VBA入門
2.繰り返し処理(For Next)|VBA入門
3.変数宣言のDimとデータ型|VBA入門
4.セルのコピー&値の貼り付け(PasteSpecial)|VBA入門
5.ひらがな⇔カタカナの変換|エクセル基本操作
6.RangeとCellsの使い方|VBA入門
7.メッセージボックス(MsgBox関数)|VBA入門
8.セルのクリア(Clear,ClearContents)|VBA入門
9.FILTER関数(範囲をフィルター処理)|エクセル入門
10.条件分岐(Select Case)|VBA入門




このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。


記述には細心の注意をしたつもりですが、
間違いやご指摘がありましたら、「お問い合わせ」からお知らせいただけると幸いです。
掲載のVBAコードは動作を保証するものではなく、あくまでVBA学習のサンプルとして掲載しています。
掲載のVBAコードは自己責任でご使用ください。万一データ破損等の損害が発生しても責任は負いません。



このサイトがお役に立ちましたら「シェア」「Bookmark」をお願いいたします。
本文下部へ