首页
/ Valibot v1.0.0 正式发布:现代化数据验证库的重大升级

Valibot v1.0.0 正式发布:现代化数据验证库的重大升级

2025-06-08 19:00:08作者:郦嵘贵Just

Valibot 是一个现代化的 TypeScript 数据验证库,它结合了类型安全和运行时验证的优势,为开发者提供了强大的工具来确保数据的完整性和正确性。随着 v1.0.0 版本的发布,Valibot 迎来了它的第一个稳定版本,带来了诸多新特性和改进。

新特性概览

增强的验证能力

Valibot v1.0.0 引入了多个新的验证动作(action),显著扩展了其验证能力:

  • assert 方法:新增的断言功能允许开发者以更直观的方式验证数据
  • 文本处理增强:新增了 graphemesmaxGraphemesminGraphemesnotGraphemes 动作,用于处理Unicode字符集
  • 单词计数验证wordsmaxWordsminWordsnotWords 动作提供了对文本中单词数量的精确控制
  • 函数转换argsreturns 动作让函数参数的验证变得更加简单
  • 电子邮件验证rfcEmail 动作严格遵循 RFC 5322 标准验证电子邮件地址
  • 数值比较gtValueltValue 动作提供了更直观的数值比较验证
  • 多值验证valuesnotValues 动作简化了多值验证场景
  • URL slug验证:新增的 slug 动作为URL slug提供了专门的验证支持

类型系统改进

Valibot v1.0.0 在类型系统方面做了多项改进:

  • ReadonlyMapReadonlySet 的支持
  • 改进了 pipepipeAync 方法的类型签名,支持无限数量的相同输入输出类型的管道项
  • 优化了 partialCheckpartialCheckAsync 动作的类型签名,以类型安全的方式添加 .pathList 属性
  • 增强了 findItem 动作以支持类型谓词
  • 改进了 MarkOptional 类型,修复了条目顺序问题

性能优化

Valibot v1.0.0 在性能方面做了多项优化:

  • 新增 entriesFromObjects 工具函数以改善tree shaking
  • 添加 @__NO_SIDE_EFFECTS__ 标记进一步优化tree shaking
  • 改进了 forwardforwardCheckpartialCheckpartialCheckAsync 的实现,提升了TypeScript的性能
  • 优化了导出结构,仅导出公共类型以减少噪音

行为变更

v1.0.0 版本包含了一些重要的行为变更:

  • 修改了 minValuemaxValueNaN 的处理方式
  • 调整了多个可空类型(nullablenullishoptional等)的默认值行为
  • 改进了对象条目缺失时的验证行为
  • 修正了 DECIMAL_REGEX 以支持以点开头的浮点数
  • 更新了 ISO_DATE_TIME_REGEXISO_TIMESTAMP_REGEX 以支持空格作为分隔符

错误修复

v1.0.0 版本修复了多个重要问题:

  • 修正了多个非可选类型在边缘情况下的实现
  • 修复了 PathKeys 类型对 any 的实例化错误
  • 解决了 keyof 方法对多键对象的TypeScript错误
  • 修正了 enum_ schema 中的选项过滤问题
  • 修复了 partialCheckpartialCheckAsync 动作对带问题的类型数据的处理

总结

Valibot v1.0.0 是一个重要的里程碑版本,它不仅标志着项目的稳定性,还带来了大量新特性和改进。从增强的验证能力到类型系统的改进,再到性能优化和错误修复,这个版本为开发者提供了更强大、更可靠的验证工具。对于正在使用或考虑使用数据验证库的TypeScript开发者来说,Valibot v1.0.0 绝对值得关注和尝试。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
261
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
860
511
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
259
300
kernelkernel
deepin linux kernel
C
22
5
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
596
57
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
371
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
332
1.08 K