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 状态和异步错误处理

相关推荐
GISer_Jing18 分钟前
[总结篇]个人网站
前端·javascript
疯狂的沙粒40 分钟前
在web-view 加载的本地及远程HTML中调用uniapp的API及网页和vue页面是如何通讯的?
前端·uni-app·html
小妖66644 分钟前
html 滚动条滚动过快会留下边框线
前端·html
heroboyluck1 小时前
Svelte 核心语法详解:Vue/React 开发者如何快速上手?
前端·svelte
海的诗篇_1 小时前
前端开发面试题总结-JavaScript篇(二)
开发语言·前端·javascript·typescript
琹箐1 小时前
ant-design4.xx实现数字输入框; 某些输入法数字需要连续输入两次才显示
前端·javascript·anti-design-vue
程序员-小李1 小时前
VuePress完美整合Toast消息提示
前端·javascript·vue.js
Uyker2 小时前
从零开始制作小程序简单概述
前端·微信小程序·小程序
EndingCoder6 小时前
React从基础入门到高级实战:React 实战项目 - 项目三:实时聊天应用
前端·react.js·架构·前端框架
阿阳微客7 小时前
Steam 搬砖项目深度拆解:从抵触到真香的转型之路
前端·笔记·学习·游戏