使用 Zod 实现类似 Yup 的 setLocale 功能

使用 zod 实现类似 yup 的 setlocale 功能

本文旨在介绍如何在 Zod 中实现类似 Yup 的 setLocale 功能,即自定义验证错误信息以支持国际化(i18n)。通过 z.setErrorMap 方法,您可以全局设置自定义错误映射,从而根据不同的错误类型和上下文返回相应的本地化错误信息。此外,我们还将介绍 zod-i18n 库,这是一个专门为 Zod 设计的 i18n 解决方案,可以更方便地集成 i18next 等 i18n 库。

Zod 是一个流行的 TypeScript 优先的模式声明和验证库。与 Yup 类似,Zod 允许您定义数据模式并验证数据是否符合这些模式。虽然 Zod 没有像 Yup 那样直接的 setLocale 方法,但它提供了 z.setErrorMap 方法,允许您自定义验证错误信息,从而实现类似的功能。

使用 z.setErrorMap 自定义错误信息

z.setErrorMap 接受一个函数作为参数,该函数接收两个参数:issue 和 ctx。issue 包含了有关验证错误的详细信息,例如错误代码、期望的类型等。ctx 包含了验证上下文,例如默认的错误信息。

以下是一个使用 z.setErrorMap 自定义错误信息的示例:

import { z } from "zod";const customErrorMap: z.ZodErrorMap = (issue, ctx) => {  if (issue.code === z.ZodIssueCode.invalid_type) {    if (issue.expected === "string") {      return { message: "必须是字符串类型" };    }    if (issue.expected === "number") {      return { message: "必须是数字类型" };    }  }  if (issue.code === z.ZodIssueCode.too_small) {    if (issue.type === "string") {      return { message: `字符串长度不能小于 ${issue.minimum}` };    }  }  return { message: ctx.defaultError };};z.setErrorMap(customErrorMap);const schema = z.object({  name: z.string().min(3),  age: z.number(),});const result = schema.safeParse({ name: "ab", age: "abc" });if (!result.success) {  console.log(result.error.format());}

在这个例子中,我们定义了一个名为 customErrorMap 的函数,该函数根据不同的错误代码返回不同的错误信息。例如,如果类型无效且期望的类型是字符串,则返回 “必须是字符串类型” 错误信息。如果字符串太短,则返回包含最小长度的错误信息。

集成 zod-i18n 实现国际化

zod-i18n 是一个专门为 Zod 设计的 i18n 库,它依赖于 i18next。使用 zod-i18n 可以更方便地实现 Zod 模式的国际化。

以下是一个使用 zod-i18n 的示例:

import i18next from "i18next";import { z } from "zod";import { zodI18nMap } from "zod-i18n-map";import translation from "zod-i18n-map/locales/zh-CN/zod.json"; // 导入中文翻译i18next.init({  lng: "zh-CN",  resources: {    "zh-CN": { zod: translation },  },});z.setErrorMap(zodI18nMap);const schema = z.string().email();try {  schema.parse("foo");} catch (error) {  if (error instanceof z.ZodError) {    console.log(error.errors[0].message); // 输出: 必须是有效的电子邮件地址  }}

在这个例子中,我们首先初始化 i18next,并加载中文翻译文件。然后,我们将 zodI18nMap 设置为 Zod 的错误映射。最后,当我们尝试解析一个无效的电子邮件地址时,Zod 会返回一个本地化的错误信息。

注意事项

确保正确配置 i18next 并加载正确的翻译文件。zod-i18n 提供了多种语言的翻译文件,您可以根据需要选择合适的翻译文件。您可以自定义 zod-i18n 提供的翻译文件,以满足您的特定需求。

总结

通过 z.setErrorMap 方法,您可以自定义 Zod 的验证错误信息,从而实现类似 Yup 的 setLocale 功能。zod-i18n 库提供了一个更方便的解决方案,可以轻松地将 Zod 集成到您的 i18n 工作流程中。选择哪种方法取决于您的具体需求和偏好。

以上就是使用 Zod 实现类似 Yup 的 setLocale 功能的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1514741.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月20日 08:40:02
下一篇 2025年12月20日 08:40:09

相关推荐

  • 从矩阵行中提取正数和并构建新数组的教程

    本教程旨在指导读者如何从二维数组(矩阵)的每一行中,筛选并计算所有正数的和,最终将这些行和构成一个新的数组。文章将深入剖析常见的编程陷阱,如求和变量的错误初始化和循环索引的偏差,并提供一套经过优化的JavaScript代码示例,确保逻辑清晰、执行准确,帮助读者掌握矩阵数据处理的关键技巧。 理解目标:…

    2025年12月20日
    000
  • 如何实现用户同意后按需加载Iframe内容(以Google Maps为例)

    本教程详细介绍了如何在用户明确同意后,通过前端技术延迟加载IFRAME内容,以满足数据隐私和合规性要求。文章通过HTML和jQuery示例,展示了如何在初始页面加载时不设置IFRAME的src属性,而是待用户点击确认按钮后再动态设置,从而有效避免了在用户未授权前加载第三方内容,提升了用户体验和数据安…

    2025年12月20日
    000
  • 解决TinyMCE在DOM重插入后无法编辑的问题

    当TinyMCE编辑器所在的DOM元素被移除又重新插入文档时,编辑器可能变得无法输入。核心原因是TinyMCE实例未被正确销毁。本文将详细讲解如何通过显式调用editor.remove()方法来解决此问题,确保编辑器在DOM操作后仍能正常工作,并提供示例代码和最佳实践。 在现代web应用开发中,动态…

    2025年12月20日
    000
  • TinyMCE在DOM中重定位后的正确初始化与管理

    本文探讨TinyMCE编辑器在从DOM中移除并重新插入后变得不可用的常见问题。核心解决方案在于,当TinyMCE容器从DOM中移除时,必须同步销毁对应的TinyMCE实例;当容器重新插入DOM后,则需重新初始化TinyMCE。通过正确的实例生命周期管理,可确保编辑器在动态内容场景下的稳定运行。 Ti…

    2025年12月20日
    000
  • 延迟加载iframe以增强用户隐私与性能:以Google Maps为例

    本教程详细讲解如何通过延迟加载iframe内容,如Google Maps,来提升用户隐私保护和网站性能。我们将介绍一种简单而有效的方法,即在用户明确同意后才动态设置iframe的src属性,从而避免在页面初始加载时泄露数据或消耗不必要的资源。 引言:隐私与性能的挑战 在现代网页开发中,嵌入第三方内容…

    2025年12月20日 好文分享
    000
  • React/TypeScript中函数作为Props传递的正确姿势与常见误区

    本文旨在解决React和TypeScript开发中,将函数作为组件props传递时出现的常见错误:“Function is missing in type but required in type ‘Props’”。核心内容是阐明了使用对象展开运算符{…funct…

    2025年12月20日
    000
  • 从二维数组行中计算正数之和并生成新数组的教程

    本教程详细阐述了如何从二维数组(矩阵)的每行中提取并计算所有正元素的总和,最终生成一个包含这些行总和的新数组。文章重点分析了常见的编程陷阱,如不正确的累加器初始化和循环边界设置,并提供了优化的JavaScript代码示例,确保准确无误地实现目标功能,提升代码的健壮性与可读性。 理解任务目标 我们的目…

    2025年12月20日
    000
  • JavaScript中根据动态键和嵌套属性值过滤对象数组的教程

    本教程将指导您如何在JavaScript中高效地过滤对象数组。我们将探讨如何根据一个动态的字符串变量来访问对象内部的特定属性键,并进一步检查该键对应的值,从而实现数据的精确筛选。通过实例,您将学习如何处理嵌套数据结构和动态键匹配,以满足复杂的业务逻辑需求。 问题概述:动态数据筛选的挑战 在现代前端或…

    2025年12月20日
    000
  • 解决 jQuery DataTables 渲染时复选框与行选择冲突的教程

    本教程旨在解决 jQuery DataTables 中,在渲染包含复选框的列时,如何基于复选框的初始状态正确选择对应行的问题。文章将深入探讨常见的“Cannot read properties of undefined (reading ‘row’)”错误,并提供一种利用 r…

    2025年12月20日
    000
  • TinyMCE编辑器在DOM重插入后失效的解决方案

    本文旨在解决TinyMCE编辑器在从文档对象模型(DOM)中移除后重新插入,导致无法输入文本的问题。核心方案在于,当其容器元素被移除时,必须同步调用tinymce.Editor.remove()方法销毁TinyMCE实例,以确保后续重新初始化时编辑器能正常响应用户输入。 问题描述与根本原因分析 在现…

    2025年12月20日
    000
  • JavaScript矩阵行正数求和:避免常见陷阱与优化方案

    本文旨在教授如何在JavaScript中正确计算矩阵每行中所有正数的总和,并生成一个新的数组。文章将深入探讨在实现此功能时常见的初始化错误和循环索引问题,提供经过优化的解决方案和示例代码,确保计算结果的准确性。 在数据处理和算法实现中,经常需要对多维数组(矩阵)进行行或列的聚合操作。其中一个常见需求…

    2025年12月20日
    000
  • JavaScript事件监听器:正确获取表单输入最新值的实践

    本文探讨了在JavaScript事件监听器中,如何正确获取HTML表单输入框的最新值。通过分析console.log直接输出DOM元素可能导致的问题,文章详细介绍了使用Array.from结合映射函数来精确提取元素value属性的解决方案,确保在提交表单数据时,能够获取到用户实时输入的内容,而非初始…

    2025年12月20日
    000
  • TinyMCE 实例在 DOM 重新插入后无法编辑的解决方案

    本教程旨在解决 TinyMCE 编辑器在被从 DOM 中移除后重新插入文档时变得不可用的问题。核心在于,在从 DOM 中移除编辑器容器之前,必须显式地调用 editor.remove() 方法来销毁 TinyMCE 实例,以确保其内部状态被正确清理。重新插入容器后,需要再次调用 tinymce.in…

    2025年12月20日
    000
  • Express 中嵌套异步数据查询并正确响应 JSON

    本文深入探讨了在 Express 应用中处理嵌套异步数据查询的常见问题,特别是当尝试将数据库查询结果(如关联的“principals”数据)嵌入到主数据对象中时可能遇到的空对象问题。核心解决方案是利用 JavaScript 的 async/await 语法,确保异步操作在数据映射和 JSON 响应发…

    2025年12月20日
    000
  • jQuery DataTables:解决渲染时复选框与行选择冲突的问题

    本文旨在解决jQuery DataTables在渲染包含复选框的表格时,如何根据复选框状态正确选择(或取消选择)对应行的问题。核心在于利用DataTables的rowCallback函数,通过正确获取DataTables API实例,并结合复选框的初始状态,实现行的程序化选择,避免“Cannot r…

    2025年12月20日
    000
  • 什么是JavaScript的异步上下文与AsyncLocalStorage的结合,以及它在Node.js中维护请求状态的作用?

    AsyncLocalStorage通过异步上下文追踪机制,在Node.js单线程环境中为每个请求维护独立的数据存储,解决了传统参数透传、全局变量和req对象传递的局限性,适用于请求追踪、多租户隔离、用户权限管理和事务控制等场景。 JavaScript的异步上下文,简单来说,就是指在Node.js这类…

    2025年12月20日
    000
  • JavaScript事件监听器获取表单最新输入值的正确姿势

    在JavaScript中,通过事件监听器获取表单文本输入框的当前值时,直接打印HTML元素对象可能无法显示用户修改后的最新值。这是因为console.log通常展示的是元素的初始DOM表示或属性快照。要获取最新的动态值,必须显式访问元素的value属性。本文将详细阐述这一常见误区,并提供使用Arra…

    2025年12月20日
    000
  • jQuery DataTables 初始渲染时基于复选框状态选择行的最佳实践

    本文详细阐述了在 jQuery DataTables 初始渲染时,如何根据复选框的选中状态正确地选择对应行,以避免常见的 “Cannot read properties of undefined (reading ‘row’)” 错误。核心在于在 ro…

    2025年12月20日
    000
  • 深入理解JavaScript属性:数组与对象的非数字键处理

    JavaScript中,所有存储的数据本质上都是对象的属性。数组的“值”实际上是其以数字为键的属性,而非数字键的属性则被视为普通对象属性。本文旨在澄清数组与对象属性的根本区别,强调当需要使用非数字键时应优先选择普通对象。我们将探讨如何利用Object.entries()遍历并筛选出对象或类数组结构中…

    2025年12月20日
    000
  • Express中处理嵌套异步数据:解决res.json()返回空对象问题

    本教程旨在解决Express应用中,当使用res.json()返回包含嵌套异步获取数据(如来自不同数据库表的关联数据)的JSON响应时,出现内部数据为空的问题。核心在于理解异步操作的执行时机,并采用async/await机制确保所有数据在构建响应前已完全解析,从而正确地将关联数据嵌入到主对象中。 引…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信