0

0

Zod 如何正确获取数组内嵌套对象的详细字段级错误信息

霞舞

霞舞

发布时间:2026-02-07 13:29:52

|

781人浏览过

|

来源于php中文网

原创

Zod 如何正确获取数组内嵌套对象的详细字段级错误信息

当使用 zod 验证包含对象数组的结构时,`flatten()` 默认无法展开嵌套字段错误;需改用 `error.format()` 方法递归提取每一层(如 `sizes[0].price`)的精确校验失败信息。

在 Zod 中,.flatten() 方法仅对顶层字段(如 sizes)做扁平化处理,不会深入数组元素内部的对象结构。因此,当你传入 sizes: [{}] 时,Zod 能识别出数组非空但首项对象缺失必填字段,却无法将 price、off_price、sell_quantity 的错误映射到对应路径下——最终只返回 "sizes":["Required","Required","Required"] 这类模糊提示,丢失关键定位信息。

要获得真正可操作的嵌套错误结构,应使用 Zod 内置的 .format() 方法。它会按数据路径(如 ['sizes', 0, 'price'])生成嵌套对象格式的错误树,完美保留层级语义:

import { z } from 'zod';

const schema = z.object({
  sizes: z
    .array(
      z.object({
        price: z.string().nonempty("价格不能为空"),
        off_price: z.string().nonempty("折扣价不能为空"),
        sell_quantity: z.string().nonempty("销量不能为空"),
      })
    )
    .nonempty("至少需提供一个规格"),
}).strict();

const result = schema.safeParse({ sizes: [{}] });

if (!result.success) {
  // ✅ 推荐:获取结构化嵌套错误
  const formatted = result.error.format();
  console.log(formatted.sizes?.[0]);
  // 输出:
  // {
  //   _errors: [],
  //   price: { _errors: ["价格不能为空"] },
  //   off_price: { _errors: ["折扣价不能为空"] },
  //   sell_quantity: { _errors: ["销量不能为空"] }
  // }

  // ✅ 也可遍历所有原始错误详情(含完整 path)
  console.log(result.error.issues);
  // [
  //   { path: ["sizes", 0, "price"], message: "价格不能为空" },
  //   { path: ["sizes", 0, "off_price"], message: "折扣价不能为空" },
  //   ...
  // ]
}

⚠️ 注意事项:

Face++旷视
Face++旷视

Face⁺⁺ AI开放平台

下载
  • z.string().nonempty() 是推荐写法(比 z.string().min(1) 更语义清晰且错误消息更友好);
  • 若需前端直接消费错误结构,format() 返回的对象可直接映射为表单控件的 name="sizes[0].price" 对应的错误提示;
  • 避免在 schema 中过度使用 .strict(),除非严格禁止额外字段——它不影响错误粒度,但可能掩盖调试线索;
  • 如需自定义错误聚合逻辑(例如合并同级多个错误为一条),可基于 error.issues 数组手动实现,format() 本身不支持插件化定制。

总结:flatten() 适用于简单表单级错误展示,而 format() 才是处理复杂嵌套结构(如数组+对象)错误的正确选择。通过其返回的嵌套对象,你能精准定位到 sizes[0].price 等任意深度字段的验证失败原因,大幅提升表单反馈体验与调试效率。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

606

2023.08.02

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

864

2023.07.31

python中的format是什么意思
python中的format是什么意思

python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

439

2024.06.27

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

309

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

317

2023.10.25

Golang处理数据库错误教程合集
Golang处理数据库错误教程合集

本专题整合了Golang数据库错误处理方法、技巧、管理策略相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.02.06

java多线程方法汇总
java多线程方法汇总

本专题整合了java多线程面试题、实现函数、执行并发相关内容,阅读专题下面的文章了解更多详细内容。

0

2026.02.06

1688阿里巴巴货源平台入口与批发采购指南
1688阿里巴巴货源平台入口与批发采购指南

本专题整理了1688阿里巴巴批发进货平台的最新入口地址与在线采购指南,帮助用户快速找到官方网站入口,了解如何进行批发采购、货源选择以及厂家直销等功能,提升采购效率与平台使用体验。

84

2026.02.06

快手网页版入口与电脑端使用指南 快手官方短视频观看入口
快手网页版入口与电脑端使用指南 快手官方短视频观看入口

本专题汇总了快手网页版的最新入口地址和电脑版使用方法,详细提供快手官网直接访问链接、网页端操作教程,以及如何无需下载安装直接观看短视频的方式,帮助用户轻松浏览和观看快手短视频内容。

15

2026.02.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Node.js 教程
Node.js 教程

共57课时 | 10.5万人学习

CSS3 教程
CSS3 教程

共18课时 | 5.2万人学习

Vue 教程
Vue 教程

共42课时 | 8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号