質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

Q&A

2回答

8268閲覧

vbModelessのフォームのフォーカスについて

julia1993

総合スコア8

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

0グッド

0クリップ

投稿2018/06/04 15:47

Excel vba のフォームについての質問です。

vbModelessでshowしたフォームのテキストボックスにフォーカスインしたいのですができません。

ブックのオープンイベントの最後で
Call frmA.show(vbModeless)で表示しており、
フォームのアクティベートイベントは以下です。

VBA

1 2Private Sub UserForm_Activate() 3 4 Me.txtA.Text = vbNullString 5 Me.txtB.Text = vbNullString 6 7 Call Me.txtA.SetFocus 8 9End Sub 10

SetFocusの後にActiveControlを取得しても空文字が返ってきます。

調べてみましたが、これといった解決方法が出てきませんでした。

ご教示お願いいたします。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

ミニマムで確認してみたでしょうか?
当方で試したところ、SetFocus はされていました。

但し、シート上のセルを選択した後にフォームを選択すると、
フォーカスが外れていました。

投稿2018/06/05 01:09

ExcelVBAer

総合スコア1175

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

極シンプルなテストプログラムで試した感じでは、問題なくできました。
txtAがDisableになっているなんてことはないですよね。
何か別の処理の弊害でフォーカスが正しく処理できていないような気がします。

原因がわからない場合、強攻策ですが、TabIndexで一番目(0)にくるように設定してしまうのはいかがでしょうか。

投稿2018/06/05 00:34

ttyp03

総合スコア16998

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問