MockPilot2 Review

为模拟面试平台中的用户身份验证模块,实现注册 / 登录功能。使用技术栈包括:

  • Next.js 13 + App Router
  • TypeScript
  • React Hook Form
  • Zod 用于 schema 校验
  • Sonner 实现 toast 提示
  • 自定义组件如 FormField, Button, Form

该项目将作为简历中的展示项目,目标是:代码清晰、逻辑完整、类型安全、可讲解


🧰 核心功能模块划分

1. 表单 Schema 生成 (authFormSchema)

  • 利用 Zod 按照身份类型动态生成 schema
  • Sign-Up 需要 name 字段,Sign-In 不需要
css 复制代码
const authFormSchema = (type: FormType) =>
  z.object({
    name: type === "sign-up" ? z.string().min(3) : z.string().optional(),
    email: z.string().email(),
    password: z.string().min(3),
  });

2. 表单形成 (React Hook Form + zodResolver)

  • useForm 和 schema 绑定
  • 用 TS 定义表单值类型
  • defaultValues 确保 RHF 初始化正确
css 复制代码
const formSchema = authFormSchema(type);
const form = useForm<z.infer<typeof formSchema>>({
  resolver: zodResolver(formSchema),
  defaultValues: {
    name: "",
    email: "",
    password: "",
  },
});

3. 提交函数 onSubmit

  • 根据 type 判断是 sign-up 还是 sign-in
  • 使用 router.push 进行跳转
  • 给与用户不同 toast feedback
vbnet 复制代码
function onSubmit(values: z.infer<typeof formSchema>) {
  try {
    if (type === "sign-up") {
      toast.success("Account created successfully. Please sign in.");
      router.push("/sign-in");
    } else {
      toast.success("Sign in successfully.");
      router.push("/");
    }
  } catch (error) {
    toast.error(`There was an error: ${error}`);
  }
}

4. 表单字段组件 FormField(✨设计亮点)

  • 自定义封装组件 FormField 用于统一表单字段逻辑:

    • 自动绑定 RHF 的 control
    • 封装 label + input 渲染逻辑
    • 支持通用 props(如 placeholder, type
ini 复制代码
<FormField
  control={form.control}
  name="email"
  label="Email"
  placeholder="Your email address"
  type="email"
/>

🔹 价值非常大

  • 减少重复代码
  • 增强表单复用性与可维护性
  • 一致化 UI 和行为逻辑

⚡️ Debug 重点回顾 (TypeScript + RHF + Zod)

❌ 1. z.infer<typeof formSchema> 使用时报错

问题原因 : formSchema 在函数体内部才声明,导致接口型别无法推断

解决方案:

ini 复制代码
// 尽量接在 formSchema 之后声明类型
const formSchema = authFormSchema(type);
type AuthFormValues = z.infer<typeof formSchema>;

❌ 2. ReturnType<typeof authFormSchema> 无法 infer

问题原因 : 没有给 authFormSchema 指定参数,结果是 infer 一个函数,而不是 schema

解决方案: 利用实际执行后的 schema 进行 infer

ini 复制代码
const schema = authFormSchema("sign-in");
type AuthFormValues = z.infer<typeof schema>;

❌ 3. FormField.tsx 路径报错

原因 : 文件名写错了,写成 FormFileld.tsx

解决: 类名和实际路径完全对应,要么改路径,要么重命名文件

javascript 复制代码
// 正确写法
import FormField from "@/components/ui/FormField";

⚡️ UI 模块设计

  • 利用 Tailwind CSS + flex + spacing 进行布局
  • 根据 type 显示或隐藏 name 输入框
  • 提供用户切换登录/注册的方便链接

✅ 总结: 我从这个小段项目中所学到的

  1. 完整路通 RHF + Zod 表单校验流程
  2. 利用 TypeScript 进行 infer 和类型分离开发
  3. 在实际设计中处理很多小混乱,学会了转化思路
  4. 从 bug 中学习自我调试,创造比照路线
  5. 使用 FormField 封装复用,提升开发质量

📅 接下来操作

  • 联系 Firebase API 或操作本地 auth.action.ts
  • 在登录成功后添加 Dashboard 控制面板模块
  • 完善 Loading 状态和异步错误处理

相关推荐
艾恩小灰灰4 分钟前
CSS中的`transform-style`属性:3D变换的秘密武器
前端·css·3d·css3·html5·web开发·transform-style
Captaincc6 分钟前
AI coding的隐藏王者,悄悄融了2亿美金
前端·后端·ai编程
天天扭码9 分钟前
一分钟解决一道算法题——矩阵置零
前端·算法·面试
抹茶san21 分钟前
el-tabs频繁切换tab引发的数据渲染混淆
前端·vue.js·element
Captaincc25 分钟前
关于MCP最值得看的一篇:MCP创造者聊MCP的起源、架构优势和未来
前端·mcp
小小小小宇29 分钟前
记录老项目Vue 2使用VueUse
前端
vvilkim29 分钟前
React Server Components 深度解析:下一代 React 渲染模式
前端·react.js·前端框架
HBR666_39 分钟前
vue3 excel文件导入
前端·excel
天天扭码43 分钟前
偶遇天才算法题 | 拼劲全力,无法战胜 😓
前端·算法·面试
小菜刀刀1 小时前
文件包含漏洞,目录遍历漏洞,CSRF,SSRF
前端·csrf