vee-validate-skilld

Painless forms for Vue.js. ALWAYS use when writing code importing "vee-validate". Consult for debugging, best practices, or modifying vee-validate, vee validate.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "vee-validate-skilld" with this command: npx skills add harlan-zw/vue-ecosystem-skills/harlan-zw-vue-ecosystem-skills-vee-validate-skilld

logaretm/vee-validate vee-validate

Painless forms for Vue.js

Version: 4.15.1 (Jun 2025) Deps: @vue/devtools-api@^7.5.2, type-fest@^4.8.3 Tags: prev: 1.0.0-beta.10 (Nov 2016), next-edge: 4.5.0-alpha.2 (Jul 2021), edge: 4.5.0-alpha.6 (Aug 2021), next: 4.5.8 (Jan 2022), alpha: 4.12.0-alpha.1 (Nov 2023), beta: 5.0.0-beta.0 (Aug 2025), latest: 4.15.1 (Jun 2025)

References: Docs — API reference, guides

API Changes

This section documents version-specific API changes for vee-validate v4.x — prioritize these over legacy patterns.

  • BREAKING: v-model support disabled by default in v4.10.0 for performance; enable via configure({ validateOnModelUpdate: true }) or per-field syncVModel source

  • NEW: defineField introduced in v4.9.0 — replaces defineComponentBinds and defineInputBinds for cleaner Composition API integration source

  • DEPRECATED: Reactive initial values deprecated in v4.12.0; use non-reactive objects or getters to prevent unintended sync source

  • NEW: useFormContext exposed in v4.14.0 for accessing form state in deeply nested components without manual injection source

  • NEW: setValue exposed on Field instances and slot props in v4.13.0 for manual value updates source

  • NEW: Composition setter hooks (useSetFieldValue, useSetFormValues, useSetFormErrors) added in v4.11.0 for external state management source

  • NEW: handleBlur accepts shouldValidate parameter since v4.10.0 to control validation triggers on blur events source

  • NEW: syncVModel accepts target model prop name as a string in v4.10.0 for custom model support source

  • NEW: isValidating state added to useForm and form slot props in v4.9.3 to track async validation status source

  • NEW: move(oldIdx, newIdx) added to FieldArray in v4.6.0 for reordering items within array fields source

  • NEW: Specialized state hooks (useIsFieldDirty, useIsFormValid, useFieldValue) added in v4.1.0 for granular state access source

  • DEPRECATED: handleInput deprecated in v4.4.0; use handleChange for both input and change events source

  • NEW: label support in defineField added in v4.12.0 for consistent error message generation source

  • NEW: ResetFormOpts with force flag added to useResetForm in v4.13.0 to clear values without merging source

Also changed: defineComponentBinds deprecated · defineInputBinds deprecated · useFieldModel deprecated · unsetValueOnUnmount config added · keepValuesOnUnmount reactivity improved · useForm validate returns object · useResetForm hook added · nested field meta querying new v4.12.3

Best Practices

  • Prefer defineField() for binding components and inputs — returns a v-model ref and a props object for clean, non-deprecated binding source
const [email, emailProps] = defineField('email', {
  validateOnBlur: true,
  props: state => ({ 'aria-invalid': !!state.errors.length })
});
  • Display errors conditionally using meta.touched — prevents "aggressive" validation where error messages appear before the user interacts with the field source

  • Use toTypedSchema() for comprehensive TypeScript safety — wraps Yup, Zod, or Valibot schemas to differentiate between input (UI) and output (submitted) types source

import { toTypedSchema } from '@vee-validate/zod';
import * as z from 'zod';

const { values } = useForm({
  validationSchema: toTypedSchema(z.object({ email: z.string().email() }))
});
  • Mark validation schemas as non-reactive — wrap schemas in markRaw or declare them outside of ref/reactive to avoid unnecessary deep reactivity overhead source

  • Tree-shake schema validator imports — only import the specific functions you need (e.g., import { string } from 'yup') to keep bundle sizes to a minimum source

  • Pass reactive field names as getters in useField — use a function (e.g., () => props.name) to ensure vee-validate tracks name changes in dynamic forms source

  • Enable keepValuesOnUnmount for multi-step forms — preserves field state when components are hidden via v-if or tab switching source

const { values } = useForm({
  keepValuesOnUnmount: true
});
  • Use field.key for stable iteration in v-foruseFieldArray provides unique identifiers that persist through array operations, unlike indices source

  • Escape field names with [] to disable automatic nesting — wrap names (e.g., [user.name]) to treat dots as literal characters rather than object paths source

  • Filter submission values with handleSubmit.withControlled() — ensures only fields explicitly registered via useField or defineField are included in the payload source

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

vue-skilld

No summary provided by upstream source.

Repository SourceNeeds Review
General

pinia-skilld

No summary provided by upstream source.

Repository SourceNeeds Review
General

vueuse-core-skilld

No summary provided by upstream source.

Repository SourceNeeds Review
General

vue-router-skilld

No summary provided by upstream source.

Repository SourceNeeds Review