Package Exports
- @colinaut/alpinejs-plugin-simple-validate
- @colinaut/alpinejs-plugin-simple-validate/dist/alpine.validate.cjs.js
- @colinaut/alpinejs-plugin-simple-validate/dist/alpine.validate.esm.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 (@colinaut/alpinejs-plugin-simple-validate) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
AlpineJS Plugin — Simple Form Validation
Very simple form validation plugin for AlpineJS. This plugin is designed, like AlpineJS itself, to be sprinkled in as needed. What this plugin does not do is impose an opinionated structure for your form data or functionality. It can be used with or without x-model.
The x-validate directive allows for simple validation and error display on individual form elements. And the $validate() magic function grants easy access to the same validation functions for use as booleans in x-show and and x-bind. You can also use the $validate() magic function to validate the form before submitting it.
Usage
Directive x-validate
- Add x-validate along with modifiers on any form element x-validate.required.email- x-model is not required as the x-validate checks the value directly
- If validation fails it adds data-error="required"with a simple error message matching the modifier to the form element's parent element.
 
- Add styles to make error messages visible and/or validation visible- Basic style: [data-error]:after { content: attr(data-error); color: red;}
- Note: I'm using the parent element as it is more convenient for styling and :after doesn't work on form elements.
 
- Basic style: 
- Optionally add options with expression syntax- Change error message x-validate.required="{error: 'full name required'}"
- Write own ad hoc test x-validate.required="{test: $el.value.includes('bunny')}"
- Or both x-validate.required="{test: $el.value.includes('bunny'), error: 'must include bunny'}"
- Note: ad hoc tests run after all validation modifiers which allows you to further limit a validation. For instance only allow twitter urls: x-validate.required.url="{test: $el.value.startsWith('https://twitter.com/'), error: 'must be a twitter url'}"
 
- Change error message 
Validation Modifiers
The following work on all input, textarea, and select fields.
NOTE: x-validate without any modifiers or ad hoc tests does nothing
- x-validate.required — valid if not empty
- x-validate.phone — valid if empty or if phone number
- x-validate.required.phone — valid if not empty and phone number
- x-validate.email — valid if email address
- x-validate.website — valid if site domain, with or without http:// or https://
- x-validate.url — valid if url, requires http:// or https://
- x-validate.number — valid if number (positive or negative; integer or decimal)
- x-validate.integer — valid if integer number (positive or negative)
- x-validate.wholenumber — valid if whole number (positive integer)
- x-validate.date — valid if valid date; if you want more complex date comparisions I recommend checking out dayjs)
Special case: checkboxes and radio buttons
If you want to make sure an individual checkbox or radio button is selected use x-validate.checked
Magic function $validate
$validate function returns true or false; Main difference is that it assumes required is true including for any specific validation options like email or phone
- $validate('hi') returns true
- $validate('') returns false
- $validate.email('') returns false
- $validate.email('hi') returns false
- $validate.email('hi@hello.com') returns true
Example
More complicated examples in examples folder. run npm run serve to view.
<form x-data="{email: '' , phone: '', yolo: ''}">
    <div>
        <label for="name">Your Name</label>
        <input type="text" id="name" name="name" x-validate.required />
    </div>
    <div>
        <label for="email">Your Email</label>
        <input type="email" id="email" name="email" x-model="email" x-validate.required.email />
    </div>
    <div>
        <label for="phone">Your Phone</label>
        <input type="phone" x-model="phone" id="phone" name="phone" x-validate.required.phone />
    </div>
    <div class="checkbox-wrapper">
        <label><input type="checkbox" x-validate.checked name="yolo" id="yolo" x-model="yolo" /> Sell all my secret data!
            YOLO!</label>
    </div>
    <!-- submit button is disabled until email and phone are added -->
    <div>
        <button type="submit" :disabled="!$validate.email(email) || !$validate.phone(phone) || !yolo">Submit</button>
    </div>
</form>
<style type="text/css">
    /* style to display the error message */
    [data-error]:after {
        margin-left: 0.5rem;
        color: red;
        font-weight: bold;
        content: attr(data-error);
    }
</style>
Installation
CDN
<script defer src="https://unpkg.com/@colinaut/alpinejs-plugin-simple-validate@1/dist/alpine.validate.min.js"></script>
<script defer src="https://unpkg.com/alpinejs@3.x.x/dist/cdn.min.js"></script>NPM/PNPM/YARN
npm i @colinaut/alpinejs-plugin-simple-validate
pnpm i @colinaut/alpinejs-plugin-simple-validate
yarn add @colinaut/alpinejs-plugin-simple-validateBundling and initializing
If you are bundling your javascript then you can initialize the plugin like so:
import Alpine from "alpinejs";
import validate from "@colinaut/alpinejs-plugin-simple-validate";
Alpine.plugin(validate);
window.Alpine = Alpine;
Alpine.start();Eleventy static site
If you are using Eleventy, and want to install locally rather than rely on the CDN, you can install via NPM/PNPM/YARN and then pass through the js file so that it is included in the output. Then you would just need to add it to the head.
eleventyConfig.addPassthroughCopy({
    "node_modules/alpinejs/dist/cdn.min.js" : "js/alpine.min.js",
    "node_modules/@colinaut/alpinejs-plugin-simple-validate/dist/alpine.validate.min.js": "js/alpine.validate.min.js",
})<script src="/js/alpine.validate.min.js" defer></script>
<script src="/js/alpine.min.js" defer></script>Acknowledgements
Built using AlpineJS plugin blueprint