Home
Validation - Do you put focus to the correct control on validation error?
  v1.0 Posted at 27/11/2012 8:06 PM by Rebecca Liu
Most fields required validation. There are three types of validations:
  • Required Field - the field should be filled in.
  • Formatting - the field must be in a correct format. e.g. currency or date.
  • Logical - the field needs to pass some validation tests in the business layer.
To show an error, display an error provider icon next to the field on the right. An example of this is shown in the figure below.
  • Validation must not be done on TextChanged, this may chew the processor if it is a logical validation. It can also give unpleasant results, e.g. when entering -6.00, as soon as the '-' is entered the validation control would turn on.
  • Validation for Required fields must be done in the validating event.
  • Validation for format should be done in parse/format methods.
  • Validation for Logic should be done in Validated, since it must be entered if required, and in correct format.
The reason for the above validation placement is that these events run in the following order:
  • Validating
  • Parse/Format
  • Validated
Centrix - Error Provider
Figure: Good Example - Error Provider Icon next to a required field
Do not show a message box after every error in validation. You may show a message box as an error summary when an OK or Apply is clicked. Make sure you warn the user that there is an error on the form when they attempt to save.
Centrix - Error Provider
Figure: Good Example - Balloon tooltips to indicate validation errors

Related rules

    Do you feel this rule needs an update?

    If you want to be notified when this rule is updated, please enter your email address:

    Comments: