Skip to content

Latest commit

 

History

History
130 lines (91 loc) · 6.09 KB

README.md

File metadata and controls

130 lines (91 loc) · 6.09 KB

jQuery-Validator

A formless validation plugin for all kinds of validation - even your own!

Features

  • Multitude of validation methods
  • Formless (can be used anywhere, regardless of markup structure)
  • Built-in error messages showing in placeholder (if you want) -IE too.
  • [NEW] Extend with your own validation plugins! (See Demos/jQueryValidatorExtend.html for an example)

Simplest use case

You need to include the jQuery library, and the actual Validator plugin.

    <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js"></script>
    <script type="text/javascript" src="js/jQuery.Validator.js"></script>

Consider the following markup, this will add a field which is required, has a length requirement of 4 to 16, an error message if the field is empty, and an error message (using placeholders), if the length requirement is not fulfilled:

    <input type="text" id="username" data-required="true" data-lengthreq="4-16" data-msg_empty="Please enter a username" data-msg_lengthreq="Please enter a username between $MINLEN$ characters, and $MAXLEN$ characters." />

And you wish to validate it now. All the requirements have already been declared in the markup, so all you have to do, is make the plugin do it's magic:

    if($("#username").Validate()){
        // SUCCESS!
    }

If you are validating a field that is not necesarily required, but does have a required format, use

<input type="text" data-validate="true" data-.... />

This is usefull for, say, phone fields that are not required, but where you want to validate the input anyways, if it is present.

This can be extended, please reffer to the demos. Also, you can (and absolutely should) use the validate on a collection of input elements!

All the messages can be customized for each individual field, as well as for all fields at once.

If you want to customize your validator even further, you can pass the Validate function a config object. This is the parameter list.

Parameters:
- [object] config: Configuration Object:
    - [bool] returnBool: Return a bool or an object.
    The object will contain valid and invalid fields.
    
    - [string] errorClass: Class(es) to be added when a field
    is invalid.
    
    - [bool] required: Are these fields required?
    
    - [bool] useInlineErrors: If true, the first error of each
    field will be printed in the fields value.
    
    - [string] invalidChars: String of invalid characters, besides the ones in the
    input field's data.
    
    - [int] minLength: Minimum length required for all elements.
    If an element has explicitly specified a min. length,
    the explicit value is used.
    
    - [int] maxLength: Same applies to maxLength as to minLength
    
	- [string] regex: A global regex test all elements must pass

    - [string/object] noInlineErrors: Selector/collection of elements
    that wont display inline errors
    
    - [string] msg_empty: Empty Field error message
    
    - [string] msg_lengthreq: Length Requirements error message
    
    - [string] msg_invalidchars: Invalid Characters error message
    
    - [string] msg_regex: No RegEx match error message
    
    - [object] customChecks: An object array of functions for custom checks.
    Return true if it passed validation, false if not. The function takes a param object:
        - [object] paramObject: Object to read from and write to.
            - [object] input (read): The current field being validated. This is for you to validate upon.
            - [string] message (write): If false is returned, what error should be used?
    
    - [function] onFieldValidated(field, passed, invalidObject)
    Callback function that gets called once per field validation.
    "passed" represents its validation result. True if the field
    passed validation, false if not.
        - [object] field: jQuery object representing the field that was
        being validated.
        
        - [bool] passed: Boolean value representing the fields validation result.
        
        - [object] invalidObject: If passed is false, an invalidObject is also
        passed, containing all the validation messages for that field, as
        well as the field itself (see invalidInputs below, the properties are the same).

Return:
    - [bool/object] True/false, or Object - depending on the configuration.
        - [bool] valid: Was all inputs valid?
        
        - [array] invalidInputs: Collection of inputs (as invalidObject) that passed validation.
            - [object] invalidObject: An object containing the element that failed
            validation, as well as the error messages.
                - [object] elem: The input field (wrapped with jQuery) that failed validation.
                - [array of string] messages: The error messages.
        - [array] validInputs: Collection of inputs (as jQuery Objects) that passed validation.
        - [array of string] messages: Array of error messages
        
        - [object] elem: jQuery Input Field

The Plugin structure can be found in the jQuery.Validator.Email.js file - the paramObj passed to the validator method contains the following:

    var params = {
        input: $this, // Input being validated
        propertyValue: propValue, // The value of the property
        configObject: config, // The config object of the current validation routine.
        dataObject:data // The data object of the current input. ( same as input.data() )
        messageMutator: function(paramObj, errorMessage) { return newErrorMesage ...} // A message mutator function for changing the error message before displaying it. See the CheckboxGroup plugin for an example.
    };