Package Exports
- @polymer/iron-validator-behavior
- @polymer/iron-validator-behavior/iron-validator-behavior.js
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@polymer/iron-validator-behavior) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
IronValidatorBehavior
Use IronValidatorBehavior to implement a custom input/form validator. Element
instances implementing this behavior will be registered for use in elements that implement
IronValidatableBehavior.
See: Documentation, Demo.
Usage
Installation
npm install --save @polymer/iron-validator-behaviorIn a Polymer 3 element that is a validator
import {PolymerElement, html} from '@polymer/polymer';
import {mixinBehaviors} from '@polymer/polymer/lib/legacy/class.js';
import {IronValidatorBehavior} from '@polymer/iron-validator-behavior/iron-validator-behavior.js';
class SampleValidator extends mixinBehaviors([IronValidatorBehavior], PolymerElement){
// This validator only validates strings, and is only valid if
// the value is "cat".
function validate(value) {
return value === 'cat';
}
}
customElements.define('sample-validator', SampleValidator);Using this validator element in an html file
<html>
<head>
<script type="module">
import '../sample-validator.js';
</script>
</head>
<body>
<sample-validator id="aValidator"></sample-validator>
<input id="input">
<script>
input.addEventListener('input', function(event) {
var valid = aValidator.validate(input.value);
if (valid)
input.removeAttribute('invalid');
else
input.setAttribute('invalid', true);
});
</script>
</body>
</html>Contributing
If you want to send a PR to this element, here are the instructions for running the tests and demo locally:
Installation
git clone https://github.com/PolymerElements/iron-validator-behavior
cd iron-validator-behavior
npm install
npm install -g polymer-cliRunning the demo locally
polymer serve --npm
open http://127.0.0.1:<port>/demo/Running the tests
polymer test --npm