Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

jquery-validation

jquery-validation513.4kMIT1.21.0

Client-side form validation made easy

jquery, jquery-plugin, forms, validation, validate

readme

jQuery Validation Plugin - Form validation made easy

release Build Status devDependency Status jsDelivr Hits

The jQuery Validation Plugin provides drop-in validation for your existing forms, while making all kinds of customizations to fit your application really easy.

Getting Started

Downloading the prebuilt files

Prebuilt files can be downloaded from https://jqueryvalidation.org/

Downloading the latest changes

The unreleased development files can be obtained by:

  1. Downloading or Forking this repository
  2. Setup the build
  3. Run grunt to create the built files in the "dist" directory

Including it on your page

Include jQuery and the plugin on a page. Then select a form to validate and call the validate method.

<form>
    <input required>
</form>
<script src="jquery.js"></script>
<script src="jquery.validate.js"></script>
<script>
    $("form").validate();
</script>

Alternatively include jQuery and the plugin via requirejs in your module.

define(["jquery", "jquery.validate"], function( $ ) {
    $("form").validate();
});

For more information on how to setup a rules and customizations, check the documentation.

Reporting issues and contributing code

See the Contributing Guidelines for details.

IMPORTANT NOTE ABOUT EMAIL VALIDATION. As of version 1.12.0 this plugin is using the same regular expression that the HTML5 specification suggests for browsers to use. We will follow their lead and use the same check. If you think the specification is wrong, please report the issue to them. If you have different requirements, consider using a custom method. In case you need to adjust the built-in validation regular expression patterns, please follow the documentation.

IMPORTANT NOTE ABOUT REQUIRED METHOD. As of version 1.14.0 this plugin stops trimming white spaces from the value of the attached element. If you want to achieve the same result, you can use the normalizer that can be used to transform the value of an element before validation. This feature was available since v1.15.0. In other words, you can do something like this:

$("#myForm").validate({
    rules: {
        username: {
            required: true,
            // Using the normalizer to trim the value of the element
            // before validating it.
            //
            // The value of `this` inside the `normalizer` is the corresponding
            // DOMElement. In this example, `this` references the `username` element.
            normalizer: function(value) {
                return $.trim(value);
            }
        }
    }
});

Accessibility

For an invalid field, the default output for the jQuery Validation Plugin is an error message in a <label> element. This results in two <label> elements pointing to a single input field using the for attribute. While this is valid HTML, it has inconsistent support across screen readers.

For greater screen reader support in your form's validation, use the errorElement parameter in the validate() method. This option outputs the error in an element of your choice and automatically adds ARIA attributes to the HTML that help with screen reader support.

aria-describedby is added to the input field and it is programmatically tied to the error element chosen in the errorElement parameter.

$("#myform").validate({
  errorElement: "span"
});
<label for="name">Name</label>
<input id="name" aria-describedby="unique-id-here">
<span class="error" id="unique-id-here">This field is required</span>

Learn more about errorElement

License

Copyright © Jörn Zaefferer
Licensed under the MIT license.

changelog

1.20.1 / 2024-06-13

Core

  • Fix remote validation when input is the same as in aborted request #2481

Localisation

  • Update Arabic translations #2485

1.20.0 / 2023-10-10

Additional

  • Fixed vinUS validation failing on valid vin numbers #2460

Core

  • Fixed race condition in remote validation rules #2435
  • Removed pending class from fields with an aborted request #2436
  • Fixed remote validation error tracking #2242
  • Added escapeHtml option to avoid XSS attacks via showLabel method #2462

Demo

  • Fixed minlength validation in ajaxSubmit-integration-demo.html #2454

Localisation

  • Improved required translation in pt_BR #2445
  • Added Hindi translation #2453
  • Added French currency translation #2471

1.19.5 / 2022-07-01

Chore

Core

  • Fixed jQuery .submit() event shorthand deprecation notice #2430
  • Fixed ReDos vulnerability in url, and url2 validation 5bbd80d

Localisation

  • Added periods to messages #2266

1.19.4 / 2022-05-19

Build

  • Add License.md to zip tarball (#2386)

Chore

  • Updated build status badges (#2424)
  • Enabled stable bot (#2425)

Core

  • Fixed validation for input type="date" (#2360)
  • Wait for pendingRequests to finish before submitting form (#2369)
  • Fixed bug for Html Editors (#2154) (#2422)
  • Fixed ReDoS vulnerability in URL2 validation (#2428)

Test

  • Switch from Travis to GitHub workflows (#2423)

1.19.3 / 2021-01-09

Core

  • CVE-2021-21252: fixed Regular Expression Denial of Service vulnerability (#2371)
  • Replaced deprecated jQuery functions (#2335)

Chore

  • Add Accessibility section to Readme (#2149)

Localization

  • Add "pattern" translation for French (#2363)
  • add phone validate translate for Turkish translation (#2343)

1.19.2 / 2020-05-23

Core

  • Core: Fixes deprecated calls to jQuery trim for compat with newer jQuery core versions (#2328)

1.19.1 / 2019-06-15

Core

  • Change focus() to trigger("focus") (#2243)

Build

  • Set jQuery as a peer dependency (#2248)

Localization

  • Add zh_TW translation for step message (#2245)
  • Adding Serbian translation for step method message (#2251)

1.19.0 / 2018-11-28

Subresource Integrity hashes

As of 1.18.0, we started to provide Subresource Integrity hashes of all distribution files.

The hashes for the 1.19.0 release can be found in the file jquery-validation-sri.json under dist folder.

Additional

  • Don't fail when field is optional in CNPJBR & CPFBR rules (#2236)
  • Add validation rule for mobile number of Russia Federation (#2207)
  • Add Brazillian CNPJ validation rule (#2222)
  • Add Brazillian CNH number (Carteira Nacional de Habilitacao) (#2234)
  • Add ABA Routing Number Validation (#2216)

Core

  • Fix contenteditable detection's regression introduced in #2142 (#2235)

Localization

  • Add Swedish translation for pattern (#2227)

1.18.0 / 2018-09-09

Additional

  • Add Brazillian PIS/NIS number validation method (#2204)
  • Add validation method for Polish telephone number (#2136)
  • Updated link to EAN docs in creditcard.js (#2120)
  • Allow N11 exchange for non-geo US phone (#2098)
  • Add new BIN range for MasterCard (#2088)
  • Add maxfiles, maxsize and maxsizetotal methods (#2087)
  • Add greaterThan and lessThan methods (#2061)

Build

  • Test on node 6.x and drop node 0.12.x (#2133)
  • Generate sub-resource integrity hashes of the distribution files (#2082)
  • Include localization files in tagged releases (#2057)
  • Include minified version of additional methods in npm package (#2057)

Core

  • Don't call submitHandler when in debug mode (#2193)
  • Cast empty data attributes to 'true' (#2182)
  • Ignore elements that belong to other/nested forms (#2147)
  • Use element.isContentEditable instead of hasAttribute (#2142)
  • Add deprecation warning to 'date' method (#2138)
  • Allow the normalizer to return any value (#2054)
  • Guard against null & undefined values in required method (#2053)

Demo

  • Add sample code for Bootstrap 4 usage (#2173)

Localization

  • Added Czech and Slovak translations for STEP method (#2197)
  • Add localized methods for italian culture (it) (#2195)
  • Add step validation string to message_zh (#2177)
  • Fix typo in pt-BR localization file (#2139)
  • Add message for phonePL method (#2136)
  • Update Norwegian language file (#2132)
  • Update Persian language file (#2122)
  • Update German language file (#2115)
  • Fix meaning in Bulgarian sentence (#2112)
  • Add remote translation to no (#2097)
  • Fixed wrong placeholder in vi translation (#2085)
  • Add missing format method in message_{fr,tr}.js files (#2075)
  • Fix typos in messages_pt_BR.js (#2073)
  • Add new danish translations (#2067)
  • Add Swedish validation message for remote (#2066)

Test

  • Cast empty data attributes to 'true' (#2182)
  • Ignore elements that belong to other/nested forms (#2147)
  • Add tests for phonePL method (#2136)
  • Add missing description to a test (#2055)
  • Required method should return false for null & undefined values (#2053)

1.17.0 / 2017-07-20

Core

  • Pass on the value of the used submit button for scripted submits (#2019)
  • Removed aria-required attribute (#2012)
  • Assign rules to contenteditable via .validate() and .rules() (#1947)
  • Count invalid fields with empty message in numberOfInvalids() (#1942)
  • Added support for button elements with descendants (#1901)
  • Add support for defining a global normalizer (#1905)

Additional

  • Add localized number validation to methods_nl.js (#2014)
  • Remove unreachable return from cifES.js (#1994)
  • Add optional support to cifES, nifES and nieES (#1966)
  • Add netmask validation method (#1955)
  • Add Polish tax id validation method (#1850)
  • Fixed validation for specific case for Spanish NIFs (#1914)

Localization

  • Added Step Range Validation to messages_ja (#1936)
  • Add hungarian step message (#1888)
  • Add Sindhi locale (#1900)
  • Added norsk step translation (#1918)
  • Add missing french step translation (#1928)
  • Added nl- translation for "step" property (#1902)
  • Add French translation for notEqualTo method (#2033)

Readme

  • Add note about trimming whitespaces inside required method (#2028)

Tests

  • Pass on the value of the used submit button for scripted submits (#2019)
  • Use assert#pushResult instead of assert#push (#2018)

All

  • Fix links after move to organization
  • Use https

Build

  • Upgrade QUnit to 2.3.3 (#2018)

1.16.0 / 2016-12-01

Additional

  • Refine cifES and nieES algorithms. Closes #1826

Build

  • Include Minified Version in NPM Package
  • Bump dev-dependencies to latest versions

Core

  • Add binding for input with button type. Closes #1891
  • Support jquery3. Closes #1866
  • Change jQuery alias 'expr[":"]' to 'expr.pseudos'

Localisation

  • Add Urdu translation. Closes #1873.

Localization

  • Fixed wrong file-extension for az translation. Closes #1890.
  • Added missing translation in pt-BR (Closes #1897)
  • Fixed typo in arabien language file.

Tests

  • Upgrade QUnit to 2.0.

UMD

  • Better support for CommonJS.

1.15.1 / 2016-07-22

Additional

  • Fix multiple mime-type validation
  • IBAN require at least 5 chars (Closes #1797, Fixes #1674)
  • Correct notEqualTo jQuery reference

Core

  • Added failing test for #1805
  • Fix group validation with 3 and more fields
  • Fix regressions introduced in #1644 and #1657 (Closes #1800)
  • Update step validation to handle floating points correctly
  • Fix error when calling $.fn.rules() on a non-form element
  • Call errorPlacement in validator scope
  • Fixed issue with contenteditable elements in forms where events for single input validation would cause exceptions

Demo

  • Add links to Bootstrap and Semantic-UI demos to index.html
  • Use .on() instead of .validateDelegate()

Localization

  • Added Azeri language

Tests

  • Added regression unit tests for PR #1760

1.15.0 / 2016-02-24

All

  • Fixed code style issues

Core

  • resetForm should also remove valid class from elements.
  • Unhighlighting field if already highlighted when using remote rule.
  • Bind the blur event just once in equalTo rule
  • Fixed error when calling .rules() on empty jquery set.
  • Fix handling of error messages with input groups.
  • Fix TypeError in showLabel when using groups settings
  • Adding a way to pass method name to remote
  • Validation fails to trigger when next field is already filled out (Fixes #1508)
  • Required rule take precedence over number & digits rules
  • Error hidden but input error class not removed
  • Remote validation uses wrong error messages
  • Fixed field highlighting with remote validation.
  • Fixed :filled selector for multiple select elements.
  • Added doc reference to jQuery.validator.methods
  • Move message processing from formatAndAdd to defaultMessage
  • ErrorList should contain only the errors that it should
  • Extract the file name without including "C:\fakepath"
  • HTML5 step attribute support. Fixes #1295
  • Added support for "pending" class on outstanding requests
  • Added normalizer (#1602)
  • Split out creditcard method
  • Escape errorID for use in the regex, not to build aria-describedby
  • Escape single quotes in names avoiding a Sizzle Error being thrown
  • Instead of using validating field's value to skip api call, use the serialized data object of the request
  • Add support for contentEditable tags

Additional

  • BIC: allow digits 1-9 in second place of location
  • Accept method regex should be escaped properly.
  • Case-insensitive check for BIC
  • Correct postalCodeCA to exclude invalid combinations
  • Make postalCodeCA method more lenient

Localization

  • Added Macedonian localization.
  • Added missing pattern message in Polish (adamwojtkiewicz)
  • Fixed Persian translation of min/max message.
  • Updated messages_sk.js
  • Update Malay translation
  • Included messages from additional methods
  • Improving pt_BR translation and fixing a typo on the 'cifES' key.

1.14.0 / 2015-06-30

Core

  • Remove unused removeAttrs method
  • Replace regex for url method
  • Remove bad url param in $.ajax, overwritten by $.extend
  • Properly handle nested cancel submit button
  • Fix indent
  • Refactor attributeRules and dataRules to share noramlizer
  • dataRules method to convert value to number for number inputs
  • Update url method to allow for protocol-relative URLs
  • Remove deprecated $.format placeholder
  • Use jQuery 1.7+ on/off, add destroy method
  • IE8 compatibility changed .indexOf to $.inArray
  • Cast NaN value attributes to undefined for Opera Mini
  • Stop trimming value inside required method
  • Use :disabled selector to match disabled elements
  • Exclude some keyboard keys to prevent revalidating the field
  • Do not search the whole DOM for radio/checkbox elements
  • Throw better errors for bad rule methods
  • Fixed number validation error
  • Fix reference to whatwg spec
  • Focus invalid element when validating a custom set of inputs
  • Reset element styles when using custom highlight methods
  • Escape dollar sign in error id
  • Revert "Ignore readonly as well as disabled fields."
  • Update link in comment for Luhn algorithm

Additionals

  • Update dateITA to address timezone issue
  • Fix extension method to only method period
  • Fix accept method to match period only
  • Update time method to allow single digit hour
  • Drop bad test for notEqualTo method
  • Add notEqualTo method
  • Use correct jQuery reference via $
  • Remove useless regex check in iban method
  • Brazilian CPF number

Localization

  • Update messages_tr.js
  • Update messages_sr_lat.js
  • Adding Perú Spanish (ES PE)
  • Adding Georgian (ქართული, ge)
  • Fixed typo in catalan translation
  • Improve Finnish (fi) translation
  • Add armenian (hy_AM) locale
  • Extend italian (it) translation with currency method
  • Add bn_BD locale
  • Update zh locale
  • Remove full stop at the end of italian messages

1.13.1 / 2014-10-14

Core

  • Allow 0 as value for autoCreateRanges
  • Apply ignore setting to all validationTargetFor elements
  • Don't trim value in min/max/rangelength methods
  • Escape id/name before using it as a selector in errorsFor
  • Explicit default for focusCleanup option
  • Fix incorrect regexp for describedby matcher
  • Ignore readonly as well as disabled fields
  • Improve id escaping, store escaped id in describedby
  • Use return value of submitHandler to allow or prevent form submit

Additionals

  • Add postalcodeBR method
  • Fix pattern method when parameter is a string

1.13.0 / 2014-07-01

All

  • Add plugin UMD wrapper

Core

  • Respect non-error aria-describedby and empty hidden errors
  • Improve dateISO RegExp
  • Added radio/checkbox to delegate click-event
  • Use aria-describedby for non-label elements
  • Register focusin, focusout and keyup also on radio/checkbox
  • Fix normalization for rangelength attribute value
  • Update elementValue method to deal with type="number" fields
  • Use charAt instead of array notation on strings, to support IE8(?)

Localization

  • Fix sk translation of rangelength method
  • Add Finnish methods
  • Fixed GL number validation message
  • Fixed ES number method validation message
  • Added galician (GL)
  • Fixed French messages for min and max methods

Additionals

  • Add statesUS method
  • Fix dateITA method to deal with DST bug
  • Add persian date method
  • Add postalCodeCA method
  • Add postalcodeIT method

1.12.0 / 2014-04-01

  • Add ARIA testing (3d5658e)
  • Add es-AR localization messages. (7b30beb)
  • Add missing dots to 'es' and 'es_AR' messages. (a2a653c)
  • Added Indonesian (ID) localization (1d348bd)
  • Added NIF, NIE and CIF Spanish documents numbers validation (#830, 317c20f)
  • Added the current form to the context of the remote ajax request (0a18ae6)
  • Additionals: Update IBAN method, trim trailing whitespaces (#970, 347b04a)
  • BIC method: Improve RegEx, {1} is always redundant. Closes gh-744 (5cad6b4)
  • Bower: Add Bower.json for package registration (e86ccb0)
  • Changes dollar references to 'jQuery', for compability with jQuery.noConflict. Closes gh-754 (2049afe)
  • Core: Add "method" field to error list entry (89a15c7)
  • Core: Added support for generic messages via data-msg attribute (5bebaa5)
  • Core: Allow attributes to have a value of zero (eg min='0') (#854, 9dc0d1d)
  • Core: Disable deprecated $.format (#755, bf3b350)
  • Core: Fix support for multiple error classes (c1f0baf)
  • Core: Ignore events on ignored elements (#700, a864211)
  • Core: Improve elementValue method (6c041ed)
  • Core: Make element() handle ignored elements properly. (3f464a8)
  • Core: Switch dataRules parsing to W3C HTML5 spec style (460fd22)
  • Core: Trigger success on optional but have other successful validators (#851, f93e1de)
  • Core: Use plain element instead of un-wrapping the element again (03cd4c9)
  • Core: make sure remote is executed last (#711, ad91b6f)
  • Demo: Use correct option in multipart demo. (#1025, 070edc7)
  • Fix $/jQuery usage in additional methods. Fixes #839 (#839, 59bc899)
  • Improve Chinese translations (1a0bfe3)
  • Initial ARIA-Required implementation (bf3cfb2)
  • Localization: change accept values to extension. Fixes #771, closes gh-793. (#771, 12edec6)
  • Messages: Add icelandic localization (dc88575)
  • Messages: Add missing dots to 'bg', 'fr' and 'sr' messages. (adbc636)
  • Messages: Create messages_sr_lat.js (f2f9007)
  • Messages: Create messages_tj.js (de830b3)
  • Messages: Fix sr_lat translation, add missing space (880ba1c)
  • Messages: Update messages_sr.js, fix missing space (10313f4)
  • Methods: Add additional method for currency (1a981b4)
  • Methods: Adding Smart Quotes to stripHTML's punctuation removal (aa0d624)
  • Methods: Fix dateITA method, avoiding summertime errors (279b932)
  • Methods: Localized methods for chilean culture (es-CL) (cf36b93)
  • Methods: Update email to use HTML5 regex, remove email2 method (#828, dd162ae)
  • Pattern method: Remove delimiters, since HTML5 implementations don't include those either. (37992c1)
  • Restricting credit card validator to include length check. Closes gh-772 (f5f47c5)
  • Update messages_ko.js - closes gh-715 (5da3085)
  • Update messages_pt_BR.js. Closes gh-782 (4bf813b)
  • Update phonesUK and mobileUK to accept new prefixes. Closes gh-750 (d447b41)
  • Verify nine-digit zip codes. Closes gh-726 (165005d)
  • phoneUS: Add N11 exclusions. Closes gh-861 (519bbc6)
  • resetForm should clear any aria-invalid values (4f8a631)
  • valid(): Check all elements. Fixes #791 - valid() validates only the first (invalid) element (#791, 6f26803)

1.11.1 / 2013-03-22

  • Revert to also converting parameters of range method to numbers. Closes gh-702
  • Replace most usage of PHP with mockjax handlers. Do some demo cleanup as well, update to newer masked-input plugin. Keep captcha demo in PHP. Fixes #662
  • Remove inline code highlighting from milk demo. View source works fine.
  • Fix dynamic-totals demo by trimming whitespace from template content before passing to jQuery constructor
  • Fix min/max validation. Closes gh-666. Fixes #648
  • Fixed 'messages' coming up as a rule and causing an exception after being updated through rules("add"). Closes gh-670, fixes #624
  • Add Korean (ko) localization. Closes gh-671
  • Improved the UK postcode method to filter out more invalid postcodes. Closes #682
  • Update messages_sv.js. Closes #683
  • Change grunt link to the project website. Closes #684
  • Move remote method down the list to run last, after all other methods applied to a field. Fixes #679
  • Update plugin.json description, should include the word 'validate'
  • Fix typos
  • Fix jQuery loader to use path of itself. Fixes nested demos.
  • Update grunt-contrib-qunit to make use of PhantomJS 1.8, when installed through node module 'phantomjs'
  • Make valid() return a boolean instead of 0 or 1. Fixes #109 - valid() does not return boolean value

1.11.0 / 2013-02-04

  • Remove clearing as numbers of min, max and range rules. Fixes #455. Closes gh-528.
  • Update pre-existing labels - fixes #430 closes gh-436
  • Fix $.validator.format to avoid group interpolation, where at least IE8/9 replaces -bash with the match. Fixes #614
  • Fix mimetype regex
  • Add plugin manifest and update headers to just MIT license, drop unnecessary dual-licensing (like jQuery).
  • Hebrew messages: Removed dots at end of sentences - Fixes gh-568
  • French translation for require_from_group validation. Fixes gh-573.
  • Allow groups to be an array or a string - Fixes #479
  • Removed spaces with multiple MIME types
  • Fix some date validations, JS syntax errors.
  • Remove support for metadata plugin, replace with data-rule- and data-msg- (added in 907467e8) properties.
  • Added sftp as a valid url-pattern
  • Add Malay (my) localization
  • Update localization/messages_hu.js
  • Remove focusin/focusout polyfill. Fixes #542 - Inclusion of jquery.validate interfers with focusin and focusout events in IE9
  • Localization: Fixed typo in finnish translation
  • Fix RTM demo to show invalid icon when going from valid back to invalid
  • Fixed premature return in remote function which prevented ajax call from being made in case an input was entered too quickly. Ensures remote validation always validates the newest value.
  • Undo fix for #244. Fixes #521 - E-mail validation fires immediately when text is in the field.

1.10.0 / 2012-09-07

  • Corrected French strings for nowhitespace, phoneUS, phoneUK and mobileUK based upon community feedback.
  • rename files for language_REGION according to the standard ISO_3166-1 (http://en.wikipedia.org/wiki/ISO_3166-1), for Taiwan tha language is Chinese (zh) and the region is Taiwan (TW)
  • Optimise RegEx patterns, especially for UK phone numbers.
  • Add Language Name for each file, rename the language code according to the standard ISO 639 for Estonian, Georgian, Ukrainian and Chinese (http://en.wikipedia.org/wiki/List_of_ISO_639-1_codes)
  • Added croatian (HR) localization
  • Existing French translations were edited and French translations for the additional methods were added.
  • Merged in changes for specifying custom error messages in data attributes
  • Updated UK Mobile phone number regex for new numbers. Fixes #154
  • Add element to success call with test. Fixes #60
  • Fixed regex for time additional method. Fixes #131
  • resetForm now clears old previousValue on form elements. Fixes #312
  • Added checkbox test to require_from_group and changed require_from_group to use elementValue. Fixes #359
  • Fixed dataFilter response issues in jQuery 1.5.2+. Fixes #405
  • Added jQuery Mobile demo. Fixes #249
  • Deoptimize findByName for correctness. Fixes #82 - $.validator.prototype.findByName breaks in IE7
  • Added US zip code support and test. Fixes #90
  • Changed lastElement to lastActive in keyup, skip validation on tab or empty element. Fixes #244
  • Removed number stripping from stripHtml. Fixes #2
  • Fixed invalid count on invalid to valid remote validation. Fixes #286
  • Add link to file_input to demo index
  • Moved old accept method to extension additional-method, added new accept method to handle standard browser mimetype filtering. Fixes #287 and supersedes #369
  • Disables blur event when onfocusout is set to false. Test added.
  • Fixed value issue for radio buttons and checkboxes. Fixes #363
  • Added test for rangeWords and fixed regex and bounds in method. Fixes #308
  • Fixed TinyMCE Demo and added link on demo page. Fixes #382
  • Changed localization message for min/max. Fixes #273
  • Added pseudo selector for text input types to fix issue with default empty type attribute. Added tests and some test markup. Fixes #217
  • Fixed delegate bug for dynamic-totals demo. Fixes #51
  • Fix incorrect message for alphanumeric validator
  • Removed incorrect false check on required attribute
  • required attribute fix for non-html5 browsers. Fixes #301
  • Added methods "require_from_group" and "skip_or_fill_minimum"
  • Use correct iso code for swedish
  • Updated demo HTML files to use HTML5 doctype
  • Fixed regex issue for decimals without leading zeroes. Added new methods test. Fixes #41
  • Introduce a elementValue method that normalizes only string values (don't touch array value of multi-select). Fixes #116
  • Support for dynamically added submit buttons, and updated test case. Uses validateDelegate. Code from PR #9
  • Fix bad double quote in test fixtures
  • Fix maxWords method to include the upper bound, not exclude it. Fixes #284
  • Fixed grammar error in german range validator message. Fixes #315
  • Fixed handling of multiple class names for errorClass option. Test by Max Lynch. Fixes #280
  • Fix jQuery.format usage, should be $.validator.format. Fixes #329
  • Methods for 'all' UK phone numbers + UK postcodes
  • Pattern method: Convert string param to RegExp. Fixes issue #223
  • grammar error in german localization file
  • Added Estonian localization for messages
  • Improve tooltip handling on themerollered demo
  • Add type="text" to input fields without type attribute to please qSA
  • Update themerollered demo to use tooltip to show errors as overlay.
  • Update themerollered demo to use latest jQuery UI (along with newer jQuery version). Move code around to speed up page load.
  • Fixed min error message broken in Japanese.
  • Update form plugin to latest version. Enhance the ajaxSubmit demo.
  • Drop dateDE and numberDE methods from classRuleSettings, leftover from moving those to localized methods
  • Passing submit event to submitHandler callback
  • Fixed #219 - Fix valid() on elements with dependency-callback or dependency-expression.
  • Improve build to remove dist dir to ensure only the current release gets zipped up

1.9.0

  • Added Basque (EU) localization
  • Added Slovenian (SL) localization
  • Fixed issue #127 - Finnish translations has one : instead of ;
  • Fixed Russian localization, minor syntax issue
  • Added in support for HTML5 input types, fixes #97
  • Improved HTML5 support by setting novalidate attribute on the form, and reading the type attribute.
  • Fixed showLabel() removing all classes from error element. Remove only settings.validClass. Fixes #151.
  • Added 'pattern' to additional-methods to validate against arbitrary regular expressions.
  • Improved email method to not allow the dot at the end (valid by RFC, but unwanted here). Fixes #143
  • Fixed swedish and norwegian translations, min/max messages got switched. Fixes #181
  • Fixed #184 - resetForm: should unset lastElement
  • Fixed #71 - improve existing time method and add time12h method for 12h am/pm time format
  • Fixed #177 - Fix validation of a single radio or checkbox input
  • Fixed #189 - :hidden elements are now ignored by default
  • Fixed #194 - Required as attribute fails if jQuery>=1.6 - Use .prop instead of .attr
  • Fixed #47, #39, #32 - Allowed credit card numbers to contain spaces as well as dashes (spaces are commonly input by users).

1.8.1

  • Added Thai (TH) localization, fixes #85
  • Added Vietnamese (VI) localization, thanks Ngoc
  • Fixed issue #78. Error/Valid styling applies to all radio buttons of same group for required validation.
  • Don't use form.elements as that isn't supported in jQuery 1.6 anymore. Its buggy as hell anyway (IE6-8: form.elements === form).

1.8.0

  • Improved NL localization (http://plugins.jquery.com/node/14120)
  • Added Georgian (GE) localization, thanks Avtandil Kikabidze
  • Added Serbian (SR) localization, thanks Aleksandar Milovac
  • Added ipv4 and ipv6 to additional methods, thanks Natal Ngétal
  • Added Japanese (JA) localization, thanks Bryan Meyerovich
  • Added Catalan (CA) localization, thanks Xavier de Pedro
  • Fixed missing var statements within for-in loops
  • Fix for remote validation, where a formatted message got messed up (https://github.com/jzaefferer/jquery-validation/issues/11)
  • Bugfixes for compatibility with jQuery 1.5.1, while maintaining backwards-compatibility

1.7

1.6

1.5.5

1.5.4

1.5.3

  • Fixed a bug related to the wrapper-option, where all ancestor-elements that matched the wrapper-option where selected (http://plugins.jquery.com/node/7624)
  • Updated multipart demo to use latest jQuery UI accordion
  • Added dateNL and time methods to additionalMethods.js
  • Added Traditional Chinese (Taiwan, tw) and Kazakhstan (KK) localization
  • Moved jQuery.format (formerly String.format) to jQuery.validator.format, jQuery.format is deprecated and will be removed in 1.6 (see http://code.google.com/p/jquery-utils/issues/detail?id=15 for details)
  • Cleaned up messages_pl.js and messages_ptbr.js (still defined messages for max/min/rangeValue, which were removed in 1.4)
  • Fixed flawed boolean logic in valid-plugin-method for multiple elements; now all elements need to be valid for a boolean-true result (http://plugins.jquery.com/node/8481)
  • Enhancement $.validator.addMethod: An undefined third message-argument won't overwrite an existing message (http://plugins.jquery.com/node/8443)
  • Enhancement to submitHandler option: When used, click events on submit buttons are captured and the submitting button is inserted into the form before calling submitHandler, and removed afterwards; keeps submit buttons intact (http://plugins.jquery.com/node/7183#comment-3585)
  • Added option validClass, default "valid", which adds that class to all valid elements, after validation (http://dev.jquery.com/ticket/2205)
  • Added creditcardtypes method to additionalMethods.js, including tests (via http://dev.jquery.com/ticket/3635)
  • Improved remote method to allow serverside message as a string, or true for valid, or false for invalid using the clientside defined message (http://dev.jquery.com/ticket/3807)
  • Improved accept method to also accept a Drupal-style comma-separated list of values (http://plugins.jquery.com/node/8580)

1.5.2

  • Fixed messages in additional-methods.js for maxWords, minWords, and rangeWords to include call to $.format
  • Fixed value passed to methods to exclude carriage return (\r), same as jQuery's val() does
  • Added slovak (sk) localization
  • Added demo for integration with jQuery UI tabs
  • Added selects-grouping example to tabs demo (see second tab, birthdate field)

1.5.1

  • Updated marketo demo to use invalidHandler option instead of binding invalid-form event
  • Added TinyMCE integration example
  • Added ukrainian (ua) localization
  • Fixed length validation to work with trimmed value (regression from 1.5 where general trimming before validation was removed)
  • Various small fixes for compatibility with both 1.2.6 and 1.3

1.5

  • Improved basic demo, validating confirm-password field after password changed
  • Fixed basic validation to pass the untrimmed input value as the first parameter to validation methods, changed required accordingly; breaks existing custom method that rely on the trimming
  • Added norwegian (no), italian (it), hungarian (hu) and romanian (ro) localization
  • Fixed #3195: Two flaws in swedish localization
  • Fixed #3503: Extended rules("add") to accept messages property: use to specify add custom messages to an element via rules("add", { messages: { required: "Required! " } });
  • Fixed #3356: Regression from #2908 when using meta-option
  • Fixed #3370: Added ignoreTitle option, set to skip reading messages from the title attribute, helps to avoid issues with Google Toolbar; default is false for compatibility
  • Fixed #3516: Trigger invalid-form event even when remote validation is involved
  • Added invalidHandler option as a shortcut to bind("invalid-form", function() {})
  • Fixed Safari issue for loading indicator in ajaxSubmit-integration-demo (append to body first, then hide)
  • Added test for creditcard validation and improved default message
  • Enhanced remote validation, accepting options to passthrough to $.ajax as parameter (either url string or options, including url property plus everything else that $.ajax supports)

1.4

  • Fixed #2931, validate elements in document order and ignore type=image inputs
  • Fixed usage of $ and jQuery variables, now fully compatible with all variations of noConflict usage
  • Implemented #2908, enabling custom messages via metadata ala class="{required:true,messages:{required:'required field'}}", added demo/custom-messages-metadata-demo.html
  • Removed deprecated methods minValue (min), maxValue (max), rangeValue (rangevalue), minLength (minlength), maxLength (maxlength), rangeLength (rangelength)
  • Fixed #2215 regression: Call unhighlight only for current elements, not everything
  • Implemented #2989, enabling image button to cancel validation
  • Fixed issue where IE incorrectly validates against maxlength=0
  • Added czech (cs) localization
  • Reset validator.submitted on validator.resetForm(), enabling a full reset when necessary
  • Fixed #3035, skipping all falsy attributes when reading rules (0, undefined, empty string), removed part of the maxlength workaround (for 0)
  • Added dutch (nl) localization (#3201)

1.3

  • Fixed invalid-form event, now only triggered when form is invalid
  • Added spanish (es), russian (ru), portuguese brazilian (ptbr), turkish (tr), and polish (pl) localization
  • Added removeAttrs plugin to facilitate adding and removing multiple attributes
  • Added groups option to display a single message for multiple elements, via groups: { arbitraryGroupName: "fieldName1 fieldName2[, fieldNameN" }
  • Enhanced rules() for adding and removing (static) rules: rules("add", "method1[, methodN]"/{method1:param[, method_n:param]}) and rules("remove"[, "method1[, method_n]")
  • Enhanced rules-option, accepts space-separated string-list of methods, eg. {birthdate: "required date"}
  • Fixed checkbox group validation with inline rules: As long as the rules are specified on the first element, the group is now properly validated on click
  • Fixed #2473, ignoring all rules with an explicit parameter of boolean-false, eg. required:false is the same as not specifying required at all (it was handled as required:true so far)
  • Fixed #2424, with a modified patch from #2473: Methods returning a dependency-mismatch don't stop other rules from being evaluated anymore; still, success isn't applied for optional fields
  • Fixed url and email validation to not use trimmed values
  • Fixed creditcard validation to accept only digits and dashes ("asdf" is not a valid creditcard number)
  • Allow both button and input elements for cancel buttons (via class="cancel")
  • Fixed #2215: Fixed message display to call unhighlight as part of showing and hiding messages, no more visual side-effects while checking an element and extracted validator.checkForm to validate a form without UI sideeffects
  • Rewrote custom selectors (:blank, :filled, :unchecked) with functions for compatibility with AIR

1.2.1

  • Bundled delegate plugin with validate plugin - its always required anyway
  • Improved remote validation to include parts from the ajaxQueue plugin for proper synchronization (no additional plugin necessary)
  • Fixed stopRequest to prevent pendingRequest < 0
  • Added jQuery.validator.autoCreateRanges property, defaults to false, enable to convert min/max to range and minlength/maxlength to rangelength; this basically fixes the issue introduced by automatically creating ranges in 1.2
  • Fixed optional-methods to not highlight anything at all if the field is blank, that is, don't trigger success
  • Allow false/null for highlight/unhighlight options instead of forcing a do-nothing-callback even when nothing needs to be highlighted
  • Fixed validate() call with no elements selected, returning undefined instead of throwing an error
  • Improved demo, replacing metadata with classes/attributes for specifying rules
  • Fixed error when no custom message is used for remote validation
  • Modified email and url validation to require domain label and top label
  • Fixed url and email validation to require TLD (actually to require domain label); 1.2 version (TLD is optional) is moved to additions as url2 and email2
  • Fixed dynamic-totals demo in IE6/7 and improved templating, using textarea to store multiline template and string interpolation
  • Added login form example with "Email password" link that makes the password field optional
  • Enhanced dynamic-totals demo with an example of a single message for two fields

1.2

  • Added AJAX-captcha validation example (based on http://psyrens.com/captcha/)
  • Added remember-the-milk-demo (thanks RTM team for the permission!)
  • Added marketo-demo (thanks Glen Lipka!)
  • Added support for ajax-validation, see method "remote"; serverside returns JSON, true for valid elements, false or a String for invalid, String is used as message
  • Added highlight and unhighlight options, by default toggles errorClass on element, allows custom highlighting
  • Added valid() plugin method for easy programmatic checking of forms and fields without the need to use the validator API
  • Added rules() plugin method to read and write rules for an element (currently read only)
  • Replaced regex for email method, thanks to the contribution by Scott Gonzalez, see http://projects.scottsplayground.com/email_address_validation/
  • Restructured event architecture to rely solely on delegation, both improving performance, and ease-of-use for the developer (requires jquery.delegate.js)
  • Moved documentation from inline to http://docs.jquery.com/Plugins/Validation - including interactive examples for all methods
  • Removed validator.refresh(), validation is now completely dynamic
  • Renamed minValue to min, maxValue to max and rangeValue to range, deprecating the previous names (to be removed in 1.3)
  • Renamed minLength to minlength, maxLength to maxlength and rangeLength to rangelength, deprecating the previous names (to be removed in 1.3)
  • Added feature to merge min + max into and range and minlength + maxlength into rangelength
  • Added support for dynamic rule parameters, allowing to specify a function as a parameter eg. for minlength, called when validating the element
  • Allow to specify null or an empty string as a message to display nothing (see marketo demo)
  • Rules overhaul: Now supports combination of rules-option, metadata, classes (new) and attributes (new), see rules() for details

1.1.2

  • Replaced regex for URL method, thanks to the contribution by Scott Gonzalez, see http://projects.scottsplayground.com/iri/
  • Improved email method to better handle unicode characters
  • Fixed error container to hide when all elements are valid, not only on form submit
  • Fixed String.format to jQuery.format (moving into jQuery namespace)
  • Fixed accept method to accept both upper and lowercase extensions
  • Fixed validate() plugin method to create only one validator instance for a given form and always return that one instance (avoids binding events multiple times)
  • Changed debug-mode console log from "error" to "warn" level

1.1.1

  • Fixed invalid XHTML, preventing error label creation in IE since jQuery 1.1.4
  • Fixed and improved String.format: Global search & replace, better handling of array arguments
  • Fixed cancel-button handling to use validator-object for storing state instead of form element
  • Fixed name selectors to handle "complex" names, eg. containing brackets ("list[]")
  • Added button and disabled elements to exclude from validation
  • Moved element event handlers to refresh to be able to add handlers to new elements
  • Fixed email validation to allow long top level domains (eg. ".travel")
  • Moved showErrors() from valid() to form()
  • Added validator.size(): returns the number of current errors
  • Call submitHandler with validator as scope for easier access of it's methods, eg. to find error labels using errorsFor(Element)
  • Compatible with jQuery 1.1.x and 1.2.x

1.1

  • Added validation on blur, keyup and click (for checkboxes and radiobutton). Replaces event-option.
  • Fixed resetForm
  • Fixed custom-methods-demo

1.0

  • Improved number and numberDE methods to check for correct decimal numbers with delimiters
  • Only elements that have rules are checked (otherwise success-option is applied to all elements)
  • Added creditcard number method (thanks to Brian Klug)
  • Added ignore-option, eg. ignore: "[@type=hidden]", using that expression to exclude elements to validate. Default: none, though submit and reset buttons are always ignored
  • Heavily enhanced Functions-as-messages by providing a flexible String.format helper
  • Accept Functions as messages, providing runtime-custom-messages
  • Fixed exclusion of elements without rules from successList
  • Fixed custom-method-demo, replaced the alert with message displaying the number of errors
  • Fixed form-submit-prevention when using submitHandler
  • Completely removed dependency on element IDs, though they are still used (when present) to link error labels to inputs. Achieved by using an array with {name, message, element} instead of an object with id:message pairs for the internal errorList.
  • Added support for specifying simple rules as simple strings, eg. "required" is equivalent to {required: true}
  • Added feature: Add errorClass to invalid field�s parent element, making it easy to style the label/field container or the label for the field.
  • Added feature: focusCleanup - If enabled, removes the errorClass from the invalid elements and hides all errors messages whenever the element is focused.
  • Added success option to show the a field was validated successfully
  • Fixed Opera select-issue (avoiding a attribute-collision)
  • Fixed problems with focussing hidden elements in IE
  • Added feature to skip validation for submit buttons with class "cancel"
  • Fixed potential issues with Google Toolbar by preferring plugin option messages over title attribute
  • submitHandler is only called when an actual submit event was handled, validator.form() returns false only for invalid forms
  • Invalid elements are now focused only on submit or via validator.focusInvalid(), avoiding all trouble with focus-on-blur
  • IE6 error container layout issue is solved
  • Customize error element via errorElement option
  • Added validator.refresh() to find new inputs in the form
  • Added accept validation method, checks file extensions
  • Improved dependency feature by adding two custom expressions: ":blank" to select elements with an empty value and �:filled� to select elements with a value, both excluding whitespace
  • Added a resetForm() method to the validator: Resets each form element (using the form plugin, if available), removes classes on invalid elements and hides all error messages
  • Fixed docs for validator.showErrors()
  • Fixed error label creation to always use html() instead of text(), allowing arbitrary HTML passed in as messages
  • Fixed error label creation to use specified error class
  • Added dependency feature: The requires method accepts both String (jQuery expressions) and Functions as the argument
  • Heavily improved customizing of error message display: Use normal messages and show/hide an additional container; Completely replace message display with own mechanism (while being able to delegate to the default handler; Customize placing of generated labels (instead of default below-element)
  • Fixed two major bugs in IE (error containers) and Opera (metadata)
  • Modified validation methods to accept empty fields as valid (exception: of course �required� and also �equalTo� methods)
  • Renamed "min" to "minLength", "max" to "maxLength", "length" to "rangeLength"
  • Added "minValue", "maxValue" and "rangeValue"
  • Streamlined API for support of different events. The default, submit, can be disabled. If any event is specified, that is applied to each element (instead of the entire form). Combining keyup-validation with submit-validation is now extremely easy to setup
  • Added support for one-message-per-rule when defining messages via plugin settings
  • Added support to wrap metadata in some parent element. Useful when metadata is used for other plugins, too.
  • Refactored tests and demos: Less files, better demos
  • Improved documentation: More examples for methods, more reference texts explaining some basics