 
nextVal is an easy-to-use, flexible and robust form validation plugin for jQuery.
Behold, the awesome.
Current version: 1.7.5
Each input should have a validate attribute. Elements can also have placeholder and title attributes.
<input type="text" validate="email" placeholder="Please enter a proper email address" />
The validate attribute can be passed multiple values, such as:
<input type="text" validate="email isempty" />
Options for the validate attribute and each respective default error message:
isempty - Please leave this field blank.
		empty - Please enter the appropriate text in this field.checked - It is required that you check this check box.alpha - Please use letters only. For example Sketchy.decimal - Please use decimal numbers only. For example 42.number - Please use numbers only. For example -4.2.email - Please enter a valid email address. For example john@somedomain.com.phone - Please enter a valid US/Canada phone number. For example (603) 555-5555.phone-intl - Please enter a valid domestic or international phone number.postal - Please enter a valid US/Canada postal code. For example 03102.date - Please enter a valid date. For example 7/3/1987.url - Please enter a valid url. For example http://www.example.comdomain - Please enter a valid domain. For example example.commin[n], max[n] or min[n]max[n] - You have not met the selection requirements.
		name attribute.It's easy to tell nextVal to validate a form. The below example would validate a form with the name "contact" and would use a summary of error messages instead of inline error messages, and the error message summary would use the content from the title attributes of form elements instead of the default error message text.
$(function() {
   $('form[name=CONTACT]').nextVal({
      useInline:false,
      useSummary:true,
      useTitles:true,
   });
});
The below function would add custom rules for ensuring the password fields match and the xheader content is valid.
$(function() {
   $('form[name=FORMNAME]').nextVal({
      customRules:[
         ['matchpassword',function($o){return !($o.val() == $('#password').val());},''],
         ['xheader',function($o){return !$o.val().match(/^X-[a-zA-Z0-9_\-]+$/);},'Please enter a valid xheader. For example X-UserData1'],
      ]
   });
});
If you're using another plugin that interacts with your form, it's easy to validate that custom functionality. For example, if you have a plugin that tests password strength, you can use nextVal to display a custom error message based on the other plugin's results:
$(function() {
   $('form[name=FORMNAME]').nextVal({
      customRules:[
         ['strongpassword',function($o){var t = $('#userform .password_strength').text();return (t == '' || t == 'Too weak' || t == 'Very weak' || t == 'Weak');},''],
      ]
   });
});
false.true, useSummary will collect all of the error messages upon form submission and display them to the user. Use with validationTag to determine the markup of the collected error messages. Use with useTitles to customize the summary content.true.true, useInline will show inline error messages when an element fails validation. This error message placement will show on form submission and may also show on blur, if onBlur is set to true.true.true, the form elements will have classes applied to them (such as placeholderStyle, passedStyle, and failedStyle). This makes it easy to style each kind of validated input.false.true, validation classes will be added to the parent of a form element that is being validated.'validation-summary'.useSummary is set to true.'validation-message'.useInline is set to true.'validation-placeholder'.'validation-passed'.'validation-failed'.'validation-ignore'.false.true, the content in the title attribute of the input field will display in the error message summary. When set to false, the default error message content for that type of field will be used in the summary. Be sure to set useSummary to true.true.true and the errorText attribute is on the input field, the errorText will be displayed as the inline error message instead of title attribute's content. If you use inline messages and the summary of error messages, the summary will still use the default text or the title attribute content if you have useTitles set to true.'vsummary-'.'vmessage-'.'ul'.ul is used, each error message will be in a li. The summary of error messages will be contained in a ul. If a div is used, each error message will be wrapped in a div.''submitButton when you are using an element for form submission that is not a submit button input type. This value could be any valid jQuery selector.function(r){return r;}.formCallback fires on form submittion after the validation is completed. It gets passed a boolian value; this reutrns true if the form passed and false if it failedfunction(r){return r;}.itemCallback functions the same way that formCallback functions, but fires after every item's validation is completed.function() {return true;}.onCall occurs when the form submission happens. Before anything is validated with that function you need to return a boolian - true to continue validating, or false to stop.false.true, form will validate a field upon an onblur event (the field losing focus). Use this in conjunction with true.false, older browsers that don't understand the placeholder attribute won't receive additional javascript hooks needed to display the placeholder text.'top'.top, bottom, custom or any jQuery selector. If you use custom, nextVal looks for an attach attribute on the element being validated for a jQuery selector.'bottom'.top, bottom, custom or any jQuery selector. If you use custom, nextVal looks for an attach attribute on the element being validated for a jQuery selector.Array().Array(Array(NAME, COMPARE FUNCTION, DEFAULT MESSAGE), ... )This form uses the validation-passed and validation-failed classes to style the input boxes.
This example uses custom text for the error message summary and default inline error message text.
This example uses custom text for the inline error messages. It also uses styled spans instead of the default list item style.
This example uses multiple rules on a single field.
This example uses a custom error rule.
This form uses the on blur and a form callback event.
Written by John Norton • Documented by Lara Swanson
© 2011