title | updated | weight | layout | category | keywords | intro | ||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
Parsley.js |
2017-10-19 |
-1 |
2017/sheet |
JavaScript libraries |
|
[Parsley](http://parsleyjs.org/doc/) provides frontend form validation.
|
{: .-three-column}
npm install --save parsleyjs
parsleyjs is the Parsley form validator. ('parsley' is a different package)
<form data-parsley-validate>
<!-- ✗ not preferred -->
$('#form').parsley(/* options */)
It's preferable to explicitly call $.fn.parsley()
.
$('#myform').parsley()
.isValid() // → true | null
.validate()
.reset()
.destroy()
$('#myform input').parsley()
.isValid()
.validate() // returns errors
<input ...>
required
type='email'
type='url'
data-parsley-type='url'
maxlength='6'
data-parsley-maxlength='6'
minlength='10'
data-parsley-minlength='10'
pattern='\d+'
data-parsley-pattern='\d+'
type='number'
data-parsley-type='number'
data-parsley-type='integer'
data-parsley-type='digits'
data-parsley-type='alphanum'
type='range'
data-parsley=range='[6, 10]'
max='10'
data-parsley-max='10'
min='6'
data-parsley-min='6'
data-parsley-mincheck='1'
data-parsley-maxcheck='3'
data-parsley-check='[1, 3]'
data-parsley-equalto='#confirm'
// Supported & excluded inputs by default
inputs: 'input, textarea, select'
excluded: 'input[type=button], input[type=submit], input[type=reset], input[type=hidden]'
// Stop validating field on highest priority failing constraint
priorityEnabled: true
See: Options
// identifier used to group together inputs
// (e.g. radio buttons…)
multiple: null
// identifier (or array of identifiers) used to
// validate only a select group of inputs
group: null
These options are only available for fields.
// Enable/disable error messages
uiEnabled: true
// Key events threshold before validation
validationThreshold: 3
// Focused field on form validation error. ‘first’|’last’|’none’
focus: 'first'
// $.Event() that will trigger validation. eg: keyup, change…
trigger: false
// Class that would be added on every failing validation
// Parsley field
errorClass: 'parsley-error'
successClass: 'parsley-success'
// Return the $element that will receive these above
// success or error classes. Could also be (and given
// directly from DOM) a valid selector like '#div'
classHandler: function (ParsleyField) {}
// Return the $element where errors will be appended.
// Could also be (and given directly from DOM) a valid
// selector like '#div'
errorsContainer: function (ParsleyField) {}
// ul elem that would receive errors’ list
errorsWrapper: '<ul class="parsley-errors-list"></ul>'
// li elem that would receive error message
errorTemplate: '<li></li>'
$('[data-parsley]').parsley({
errorsContainer (field) {
return field.$element.closest('.block, .control')
}
})
Appends the error to the closest .block
or .control
.
$('[data-parsley]').parsley({
errorClass: '-error',
successClass: '-success',
errorsWrapper: '<ul class="parsley-error-list"></ul>',
errorTemplate: '<li class="parsley-error"></li>'
})
Uses custom markup.
$('[data-parsley]').parsley({
classHandler (field) {
const $parent = field.$element.closest('.input-group')
if ($parent.length) return $parent
return field.$element
}
})
Applies the errorClass
and successClass
to the closest .input-group
, if available.
<input type='text' data-parsley-multiple-of='3' />
window.Parsley
.addValidator('multipleOf', {
// string | number | integer | date | regexp | boolean
requirementType: 'integer',
// validateString | validateDate | validateMultiple
validateNumber (value, requirement) {
return 0 === value % requirement
},
messages: {
en: 'This value should be a multiple of %s'
}
})
See: Custom validators
- Parsley documentation (parsleyjs.org)