Skip to content

Field

The <Field /> is a flexible component designed to handle most use cases. By default, it renders an HTML input element.

vue
<script lang="ts" setup>
import { useForm } from 'vue-formify';

const { Form, Field } = useForm();
</script>

<template>
	<Form>
		<Field name="first_name" />
		<button>Send</button>
	</Form>
</template>

TIP

You can set any other input attributes to this component like disbaled or maxlength

Render inputs

Select

To use the native select input you need to set as="select" property and then use it as the native.

Simple select
vue
<template>
    <Form @submit="sendForm">
        <Field name="favourite_fruit" as="select">
            <option value="apple">Apple</option>
            <option value="banana">Banana</option>
            <option value="orange">Orange</option>
        </Field>
    </Form>
</template>
Multiple select

Add multiple attribute for multi select input.

vue
<template>
    <Form @submit="sendForm">
        <Field name="favourite_fruit" as="select" multiple>
            <option value="apple">Apple</option>
            <option value="banana">Banana</option>
            <option value="orange">Orange</option>
        </Field>
    </Form>
</template>

Basic custom input

You can also wrap your custom input between Field component and binding the field value to the input.

vue
<template>
    <Form @submit="sendForm">
        <Field name="favourite_fruit" v-slot={field, error}>
            <label>Email</label>
            <input type="email" v-bind="field" />
            <small>{{ error }}</small>
        </Field>
    </Form>
</template>

Api reference

Props

PropDescription
nameField name
defaultField default value
ignoreIgnore field when extract data
trueValueCustom true value
falseValueCustom false value
preservePreserve field value when field is unmounted
asRender field as input (default), select

Slots

SlotParameterDescription
default{ field: { value: T }, errors }Gives back the field data and errors.