2020-02-27 17:47:15 -05:00
< p align = "center" > < a href = "https://vueformulate.com" target = "_blank" rel = "noopener noreferrer" > < img width = "100" src = "https://assets.wearebraid.com/vue-formulate/logo.png" alt = "VueFormulate" > < / a > < / p >
2018-01-31 17:20:29 -05:00
2020-02-27 17:33:29 -05:00
< p align = "center" >
2020-02-27 17:47:15 -05:00
< a href = "https://travis-ci.org/wearebraid/vue-formulate" > < img src = "https://travis-ci.org/wearebraid/vue-formulate.svg?branch=master" > < / a >
< a href = "https://www.npmjs.com/package/ @braid/vue -formulate" >< img alt = "npm" src = "https://img.shields.io/npm/v/ @braid/vue -formulate" ></ a >
< a href = "https://github.com/wearebraid/vue-formulate" > < img alt = "GitHub" src = "https://img.shields.io/github/license/wearebraid/vue-formulate" > < / a >
2020-02-28 10:46:08 -05:00
< a href = "" > < img src = "https://img.badgesize.io/wearebraid/vue-formulate/master/dist/formulate.esm.js.svg?compression=gzip&label=gzip" > < / a >
2020-02-27 17:33:29 -05:00
< / p >
2020-02-27 22:45:32 -05:00
< p align = "center" >
< a href = "https://vueformulate.com" > Documentation Website< / a >
< / p >
2020-02-27 17:33:29 -05:00
### What is Vue Formulate?
2020-02-29 04:40:28 +01:00
Vue Formulate is the easiest way to build forms using Vue. Key features include
2020-03-08 10:20:02 -04:00
form and field validation, file uploads, form generation, single-element inputs that support labels, help text, error messages, placeholders and more, and [comprehensive documentation ](https://vueformulate.com ) for use within your own projects.
2020-02-27 17:33:29 -05:00
2020-03-09 10:27:33 -04:00
### Vue Formulate lets you:
✓ Create any input element with a single component< br >
✓ Use `v-model` [binding ](https://vueformulate.com/guide/#model-binding ) on fields and entire forms< br >
2020-03-09 10:48:15 -04:00
✓ [Re-populate an entire form ](https://vueformulate.com/guide/forms/#setting-initial-values ) from a single object< br >
✓ [Generate a form ](https://vueformulate.com/guide/forms/#generating-forms ) using json< br >
2020-03-09 10:27:33 -04:00
✓ Easily add field labels< br >
✓ Easily add help text< br >
2020-03-09 10:48:15 -04:00
✓ Easily add [form validation ](https://vueformulate.com/guide/validation )< br >
✓ Easily add [custom validation ](https://vueformulate.com/guide/validation/#custom-validation-rules ) rules< br >
✓ Easily create custom [validation messages ](https://vueformulate.com/guide/validation/#customize-validation-messages )< br >
✓ Easily create [custom inputs ](https://vueformulate.com/guide/custom-inputs )
2020-03-09 10:27:33 -04:00
2020-03-09 10:29:49 -04:00
There's a lot more available to read at the comprehensive [documentation website ](https://vueformulate.com ).
2020-03-09 10:27:33 -04:00
2020-03-08 10:24:37 -04:00
v-model an entire form | Well-considered file uploads
:-------------------------:|:------------------------------:
![v-model an entire form ](https://assets.wearebraid.com/vue-formulate/formulate-form.gif ) | ![well-considered file uploads ](https://assets.wearebraid.com/vue-formulate/formulate-uploads.gif )
2020-03-08 10:20:02 -04:00
### How is Vue Formulate used?
The syntax is what developers would expect. To create an input you use the `FormulateInput` element and provide it with a few props:
2020-02-27 17:33:29 -05:00
```vue
< FormulateInput
v-model="value"
type="email"
name="email"
label="What is your email address"
help="Where should we contact you?"
validation="required|email"
/>
```
2020-03-08 10:20:02 -04:00
Collecting multiple `FormulateInput` elements within a single `FormulateForm` element (even deeply nested) allows you to `v-model` your entire form.
2020-03-09 10:28:31 -04:00
2020-03-09 10:29:49 -04:00
### Comprehensive Documentation
2020-03-09 10:28:31 -04:00
There's a lot more available to read at the comprehensive [documentation website ](https://vueformulate.com ).