
No.1ベストアンサー
- 回答日時:
ここでいう検証というのは,コントロールの値がその項目に関して正しいかどうかの検証です。
例えば,電話番号を入力する欄に数字以外が入っていたら,そのコントロールの値は不正となります。
# 何が正しいかは,プログラマが決定します。
Validatingイベントは入力された内容を検証するためのイベントです。
検証結果が正しくなかった場合は,
・e.Cancelの値をTrueにする
・関連するErrorProviderに,検証に失敗した理由を設定する
という処理を行います。
Validatedイベントは,Validatingイベントで検証が失敗しなかった場合に発生する後始末用のイベントです。
・関連するErrorProviderから,値を除去する
という処理を行います。
これらのイベントは,CausesValidationプロパティがTrueのコントロールで発生します。
入力の無いコントロールや,自由入力欄の様なコントロールでは,CausesValidationをFalseに設定することで,不要な検証をしないことができます。
MSDNのサンプルコードなども実行してみると,どういうものかがわかると思います。
個人的にはWinFormsといえどもデータバインディングで処理を行うため,
Validating/Validatedイベントを使うことはないです。
データバインドさせるオブジェクトで当然検証を行いますが,
だいたいは処理可能・不可能を意味するプロパティで検証結果を代替しています。
# IDataErrorInfoが必要なほどリッチなエラー情報を扱っていない……・。
References)
MSDN: Control.Validating イベント (System.Windows.Forms)
http://msdn.microsoft.com/ja-jp/library/system.w …
MSDN: Windows フォームでのユーザー入力の検証
http://msdn.microsoft.com/ja-jp/library/ms229603 …
Blog: エラーチェックの体系的な分類と実装パターン - とあるコンサルタントのつぶやき - Site Home - MSDN Blogs
http://blogs.msdn.com/b/nakama/archive/2009/09/2 …
Blog: 双方向データバインドによる単体入力エラーチェック - とあるコンサルタントのつぶやき - Site Home - MSDN Blogs
http://blogs.msdn.com/b/nakama/archive/2009/02/2 …
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
VB.NETで DataRow()を利用して、値からコードを取得したい。
Visual Basic(VBA)
-
VB.net 重複チェックがしたいです
Visual Basic(VBA)
-
タブキー押下時のイベントをひろいたい。
Visual Basic(VBA)
-
-
4
.NET - 配列変数を省略可能の引数にする方法
Visual Basic(VBA)
-
5
DataGridViewで入力チェック後、フォーカスをあてたい
Visual Basic(VBA)
-
6
PreviewKeyDownイベントが2回発生する
Visual Basic(VBA)
-
7
Designer.vbは直接コードをいじってはだめ?
Visual Basic(VBA)
-
8
VB.NET ボタン押下で一つ前のコントロールへ
Visual Basic(VBA)
-
9
DataGridViewの桁数制限に関して
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
excel vbaでユーザーフォームに...
-
Excel VBA で Richtextboxを使...
-
カメラスクロールするのを動画...
-
長いソースをサブルーチンで分割
-
全てのオブジェクトのプロパテ...
-
コンボボックスの文字によるif...
-
EXCELでactivexコントロールを...
-
USB I/Oのデジタル信号をvbaで...
-
VB6のユーザーコントロールがメ...
-
LCD 1602ディスプレイの輝度調...
-
無償で利用できる暗号化ライブラリ
-
vb.netで画面のコントロールId...
-
C#で角が丸いテキストボックス
-
Excelコマンドボタン名を変数に...
-
WIN32でOCXを利用する方法を教...
-
(VBA)スピンボタンの大量...
-
ExcelVBAでListViewが使用できない
-
プロパティをループで指定する
-
コントロールのグループ化
-
エクセルVBAユーザーフォーム・...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
エクセルVBAでオプションボタン...
-
エクセル・VBA CheckBoxのオブ...
-
カメラスクロールするのを動画...
-
EXCELでactivexコントロールを...
-
VBA ユーザーフォームの Keypre...
-
'ckbl' コントロールは作成され...
-
ExcelVBAでListViewが使用できない
-
チェックボックスをオンにした...
-
ユーザーフォームで動的(Me.Con...
-
chr関数の呼び出しで「プロ...
-
全てのオブジェクトのプロパテ...
-
vb.netで画面のコントロールId...
-
間違えて配置してしまったコン...
-
Excel VBA で Richtextboxを使...
-
VBAのフォームでTextBoxがいっ...
-
OCXって何ですか?
-
C# Form上に配置されたコントロ...
-
エクセル コントロールツール...
-
変数をコントロール型で使用す...
-
Groupboxの配下のコントロール...
おすすめ情報