
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)
-
タブキー押下時のイベントをひろいたい。
Visual Basic(VBA)
-
型 varchar から型 numeric への変換エラー。
その他(データベース)
-
-
4
.NET - 配列変数を省略可能の引数にする方法
Visual Basic(VBA)
-
5
DataGridViewで入力チェック後、フォーカスをあてたい
Visual Basic(VBA)
-
6
Loadイベント中にほかのイベントを発生したくない
その他(プログラミング・Web制作)
-
7
VB.net 重複チェックがしたいです
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ExcelVBAのコントロールの種類...
-
VBA ユーザーフォームの Keypre...
-
WEBユーザーコントロール
-
Shapeコントロールの.NET移行方法
-
chr関数の呼び出しで「プロ...
-
'ckbl' コントロールは作成され...
-
カメラスクロールするのを動画...
-
Webカスコンってなんですか?
-
コンポーネント名を変数で指定
-
シートに2つ以上のActiveXコン...
-
EXCELでactivexコントロールを...
-
ControlTipTextの書式設定(Font...
-
エクセル・VBA CheckBoxのオブ...
-
VB.net webアプリケーションで...
-
エクセル IEをコピーし貼り付け...
-
WinAPIで電卓をクリック
-
VB6でシリアルポートの制御
-
エクセルVBAで2種類のCheckbox...
-
C# タブのコントロール取得
-
OCXって何ですか?
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ExcelVBAのコントロールの種類...
-
EXCELでactivexコントロールを...
-
ExcelVBAでListViewが使用できない
-
'ckbl' コントロールは作成され...
-
カメラスクロールするのを動画...
-
VBA ユーザーフォームの Keypre...
-
vb.netで画面のコントロールId...
-
エクセル・VBA CheckBoxのオブ...
-
chr関数の呼び出しで「プロ...
-
エクセルVBAでオプションボタン...
-
Groupboxの配下のコントロール...
-
エクセル コントロールツール...
-
Labelコントロールの(左右)余...
-
チェックボックスをオンにした...
-
Excel VBA で Richtextboxを使...
-
アクセス特有の書き方?
-
(VBA)スピンボタンの大量...
-
ActiveX DLL と ActiveXコント...
-
C# ユーザコントロール内のボタ...
-
Excel VBA 動的に作成したチェ...
おすすめ情報