ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
タブ順序とは
Windows フォームでは Tab キーを押すと、フォーカスが次のコントロールに移動します。TabIndex プロパティで遷移順を制御できます。ユーザビリティ上、入力フォームでは必ず意図した順番に設定すべきです。
方法1: View → Tab Order メニュー(Windows Forms)
- Visual Studio でフォームをデザイナで開く
- メニューから 表示(View) → タブ オーダー(Tab Order)
- 各コントロールの左上に青い番号が表示される
- 遷移させたい順にコントロールを左クリック(0 から自動採番)
- 最後にもう一度 View → Tab Order でモードを抜ける(または Esc)
このモードでは GroupBox / Panel などコンテナも独自に番号を持ち、内側のコントロールはコンテナの中で再採番されます(例: 1.0, 1.1, 1.2)。
方法2: TabIndex プロパティを直接編集
Properties ウィンドウから個別にプロパティを編集する方法:
// デザイナで自動生成される箇所(Form1.Designer.cs)
this.textBoxName.TabIndex = 0;
this.textBoxEmail.TabIndex = 1;
this.comboBoxCountry.TabIndex = 2;
this.checkBoxAgree.TabIndex = 3;
this.buttonSubmit.TabIndex = 4;
this.buttonCancel.TabIndex = 5;
| プロパティ | 意味 | デフォルト |
|---|---|---|
| TabIndex | タブ順の番号(小さい順に遷移) | 追加順 |
| TabStop | Tab で停止するか | true |
| CausesValidation | フォーカス移動時に検証イベント発火 | true |
TabStop = false で除外
Label のようにフォーカスする必要のないコントロールでも、Button や CheckBox で「タブで止めたくない」場合があります:
// 「ヘルプ」ボタンはタブでは止まらないが、マウスクリックは可能
buttonHelp.TabStop = false;
// PictureBox はデフォルトで TabStop=false
pictureBox1.TabStop = false;
// Label は TabStop が無い(フォーカス自体できない)
// ただし TabIndex は持っている(後続コントロールの & アクセラレータキー用)
コンテナ内のタブ順
GroupBox / Panel / TabControl 内のコントロールは、コンテナ自体の TabIndexが外側の順序を決め、内側はコンテナ内で 0 から再採番されます:
Form1
├── textBoxName TabIndex = 0
├── GroupBox1 TabIndex = 1
│ ├── radioMale TabIndex = 0 (内側)
│ ├── radioFemale TabIndex = 1 (内側)
│ └── radioOther TabIndex = 2 (内側)
├── buttonOK TabIndex = 2
└── buttonCancel TabIndex = 3
タブ遷移:
textBoxName → radioMale → radioFemale → radioOther → buttonOK → buttonCancel
WPF の場合
WPF では TabIndex プロパティのほか、KeyboardNavigation 添付プロパティで細かい制御ができます:
<Window x:Class="MyApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
Title="ユーザー登録" Height="300" Width="400">
<StackPanel KeyboardNavigation.TabNavigation="Cycle">
<TextBox Name="txtName" TabIndex="0" />
<TextBox Name="txtEmail" TabIndex="1" />
<ComboBox Name="cmbCountry" TabIndex="2" />
<Button Name="btnHelp" TabIndex="-1" IsTabStop="False" Content="ヘルプ" />
<Button Name="btnSubmit" TabIndex="3" Content="送信" />
<Button Name="btnCancel" TabIndex="4" Content="キャンセル" />
</StackPanel>
</Window>
KeyboardNavigation.TabNavigation の値
| 値 | 動作 |
|---|---|
| Continue | デフォルト。コンテナを通過して次へ |
| Cycle | このコンテナ内を循環 |
| Once | このコンテナを 1 度だけ通過 |
| Local | このコンテナ内のみ |
| None | このコンテナ内のタブ移動を無効化 |
自動 TabIndex(Visual Studio の生成順)
Visual Studio はデザイナでコントロールを追加した順に TabIndex を自動採番します。後から並べ替えると順番がおかしくなりがちです:
- レイアウト変更後は必ず View → Tab Order で確認
- 動的に追加するコントロールには明示的に TabIndex を代入する
- Visual Inheritance では親フォームの TabIndex を継承するので注意
ユーザビリティ上の重要性
- ログインフォーム: ユーザー名 → パスワード → ログインボタンの順は絶対
- 申込フォーム: 上から下、左から右の視線移動順と一致させる
- キーボード専用ユーザー(マウス使えない / アクセシビリティ重視)にとって必須
- JIS X 8341 や WCAG 2.1 (2.4.3 Focus Order) でも明確化を要求
動的に追加したコントロールのタブ順
// プログラムから動的に追加する場合
private void AddRow(int rowIndex)
{
var label = new Label { Text = "項目" + rowIndex, Top = rowIndex * 30, Left = 10 };
var textBox = new TextBox { Top = rowIndex * 30, Left = 100, TabIndex = rowIndex };
this.Controls.Add(label);
this.Controls.Add(textBox);
}
// 後から一括でタブ順を再構築
private void RebuildTabOrder()
{
var inputs = this.Controls.OfType<TextBox>()
.OrderBy(t => t.Top)
.ThenBy(t => t.Left)
.ToList();
for (int i = 0; i < inputs.Count; i++)
{
inputs[i].TabIndex = i;
}
}
FAQ
Q: Tab Order メニューがグレーアウト
A: コードビューにいる、もしくはユーザーコントロールを開いている。フォームデザイナをアクティブにする。
Q: TabIndex を変えても遷移順が変わらない
A: コンテナ(GroupBox 等)の中にあると、コンテナの TabIndex が外側の順序を決める。内側の TabIndex はコンテナ内のみ。
Q: 矢印キーで RadioButton 間を移動したい
A: 同じグループ内の RadioButton は自動的に矢印キーで移動可能。Tab では全体で 1 度しか止まらない(選択中のものだけ)。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- ショートカットキー
- dllを参照する方法
- エラー一覧
- 本番環境のdll内で参照しているdllファイルの置き場所
- フォームのタブ切り替え順序を変更する方法
- .suoファイルとは
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?