10 分钟构建 Vue 3 端到端类型安全的表单

概述

在前端开发中,表单是用户交互的核心,但同时也是最容易出错的部分。字段名拼写错误、字段类型不一致、数据验证缺失,都会导致运行时错误、难以维护的代码,甚至安全隐患。

随着应用变得复杂,需要一种方式:

  • 从定义到提交全链路保证字段类型的一致性
  • 能让 TS 类型系统真正参与到表单开发的每一层
  • 能减少手动维护冗余类型,提高开发效率和可维护性

在本文中,我们通过 vue3 实现一个类型安全的 Form

创建 vue3 项目

通过 pnpm 创建一个 vue3 的 repo

bash 复制代码
pnpm create vue@latest

如何构建表单

使用 @vee-validate/zod

bash 复制代码
pnpm install vee-validate @vee-validate/zod

小试牛刀

App.js 复制代码
<script setup>
import { useForm } from 'vee-validate';
import { toTypedSchema } from '@vee-validate/zod';
import { z } from 'zod';

const { handleSubmit, defineField, isSubmitting, errors, meta, setFieldError } = useForm({
  validationSchema: toTypedSchema(z.object({
    name: z.string(),
    age: z.number().min(1),
  })),
});

const [name, nameAttrs] = defineField('name');
const [age, ageAttrs] = defineField('age');

const onSubmit = handleSubmit(async (values) => {
  console.log('Submitting...');
  await new Promise(resolve => setTimeout(resolve, 2000));
  console.log('Done!', values);
});

</script>

<template>
  <form @submit="onSubmit">
    <div>
      <label for="name">Name:</label>
      <input v-model="name" v-bind="nameAttrs" @input="() => setFieldError('name', '')" />
      <span>{{ errors.name }}</span>
    </div>
    <div>
      <label for="age">Age:</label>
      <input v-model="age" v-bind="ageAttrs" type="number" @input="() => setFieldError('age', '')" />
      <span>{{ errors.age }}</span>
    </div>
    <button :disabled="isSubmitting">
      {{ isSubmitting ? 'Submitting...' : 'Submit' }}
    </button>
    <pre>{{ meta }}</pre>
  </form>
</template>
相关推荐
陈随易42 分钟前
编程语言级别的Skill市场,AI Agent 的未来形态
前端·后端·程序员
SoaringHeart2 小时前
Flutter进阶:基于 EasyRefresh 的下拉刷新封装 n_easy_refresh_mixin.dart
前端·flutter
IT_陈寒3 小时前
Vite的热更新突然不香了,排查三小时差点砸键盘
前端·人工智能·后端
子兮曰4 小时前
Agency-Agents 深度解析:400+ AI 专家的"梦之队"如何重塑开发工作流
前端·后端·vibecoding
竹林8185 小时前
用 The Graph 查询链上数据实战:从手搓 RPC 到 Subgraph,我的 NFT 项目数据加载快了 10 倍
前端·javascript
妙码生花5 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十九):点选验证码代码逐行目检
前端·后端·go
Awu12276 小时前
⚡从零开发 Agent CLI(五)实现一个可治理、可扩展的工具系统
前端·人工智能·claude
咪库咪库咪6 小时前
Vue3-生命周期
前端
莪_幻尘6 小时前
你的 AI Skill 越多越蠢?Token 上下文爆炸的求生指南
前端·ai编程
lichenyang4537 小时前
从 has.echo 到异步 API 注册表:一次 ASCF API 回调不触发的排查复盘
前端