”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何使用 Yup 验证字符串数组

如何使用 Yup 验证字符串数组

发布于2024-07-30
浏览:869

How to Validate Array of Strings using Yup

你好!在本教程中,您将学习如何使用 Yup 验证库验证字符串数组。首先,您将学习如何验证字符串,然后将其应用于数组。我最近遇到了这个问题,表单要求每个输入字段不能为空。我将在本教程中分享我是如何做到的。

什么是是?

Yup 是一个流行的、简单的、开源的、用于 JavaScript(和 Typescript)的运行时验证库。 Yup 是一个 JavaScript 模式验证库,它提供了一种以声明性且易于使用的方式定义和验证数据模式的方法。它通常用于前端开发,特别是表单和数据输入验证。开发人员可以使用 Yup 的 API 创建验证模式,指定他们期望的数据的形状和约束。

介绍

假设,您正在实现一个用户可以输入多封电子邮件的表单。您必须检查每封电子邮件是否有效,但如何实际创建一个架构,其中每封电子邮件都被验证为电子邮件?

import { object, string, array } from 'yup'

const schema = object({
  emails: array() //how do you validate each email in the array as an actual email? 
});

如何验证字符串

要验证 yup 中的字符串,您必须使用 string() 函数,以及其他函数。

例如,如果您需要有效的电子邮件,则可以使用 string().email().

import { object, string, array } from 'yup'

const schema = object({
  email: string().email()
});

const isValid = schema.isValidSync({
    emails: ["", "@test.com"],
  });
console.log(isValid); //true which is wrong since they are clearly not emails

如果需要必填字段,可以使用string().required().

import { object, string, array } from 'yup'

const schema = object({
  requiredField: string().required()
});

这很简单,现在让我们将其应用到数组。

如何验证 Yup 中的字符串数组

要验证 yup 中的字符串数组,您必须使用 array().of() 函数指定要验证的数组类型。例如:

import { object, string, array } from 'yup'

//1. create a simple validation schema for the string
const requiredEmail = string().email().required("Email is required");

//2. apply it to the array().of() function
const schema = object({
  emails: array().of(requiredEmail)
});

现在,当我们尝试使用一些数据再次测试它时,我们得到了正确的结果:

let isValid = schema2.isValidSync({
  emails: ["", "@test.com"],
});
console.log(isValid); //false

isValid = schema2.isValidSync({
  emails: ["[email protected]", "[email protected]"],
});
console.log(isValid); //true

如何验证其他类型的数组

同样,如果您想验证数字数组或任何类型,您可以使用相同的技术。例如:

import { object, string, array, number, boolean } from "yup";

const requiredNumber = number().required();
const optionalBoolean = boolean().optional();
const user = object({
  firstName: string().required(),
  lastName: string().required(),
});
const schema3 = object({
  numbers: array().of(requiredNumber), // array of numbers
  booleans: array().of(optionalBoolean), //array of booleans
  users: array().of(user),  // array of objects
});

基本上就是这样!

结论

您学习了如何在使用 Yup 时验证字符串数组。您还学习了如何使用 array().of() 函数验证其他类型的数组以及创建复杂的数组模式。无论你能用单个对象做什么,你也可以用数组来做。

版本声明 本文转载于:https://dev.to/suleman_ahmed_rajput/how-to-validate-array-of-strings-using-yup-gcl?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 我可以在CSS中使用SVG作为伪元素吗?
    我可以在CSS中使用SVG作为伪元素吗?
    使用svgs用作pseudo-element content css content properts允许在使用元素之前或之后使用元素插入各种类型的内容伪元素,例如::之前和::之后。但是,对可以包括哪些内容有限制。可以将svgs用作pseudo-element Content?,现在可以使用s...
    编程 发布于2025-02-06
  • HTML格式标签
    HTML格式标签
    HTML 格式化元素 **HTML Formatting is a process of formatting text for better look and feel. HTML provides us ability to format text without us...
    编程 发布于2025-02-06
  • 如何从PHP服务器发送文件?
    如何从PHP服务器发送文件?
    将文件发送到user
    编程 发布于2025-02-06
  • 如何克服PHP的功能重新定义限制?
    如何克服PHP的功能重新定义限制?
    克服PHP的函数重新定义限制在PHP中,多次定义一个相同名称的函数是一个no-no。尝试这样做,如提供的代码段所示,将导致可怕的“不能重新列出”错误。 // error:“ coss redeclare foo()” 但是,php工具腰带中有一个隐藏的宝石:runkit扩展。它使您能够灵活地...
    编程 发布于2025-02-06
  • 您什么时候需要取消多层指针?
    您什么时候需要取消多层指针?
    使用多个级别的指针是有道理的: 在面向对象的编程上下文中,可以使用三重指针来表示复杂的指针层次结构。例如,考虑以下C类结构:类A { 民众: char *b; }; B级{ 民众: char *c; }; 在这里,A对象包含一个指向B对象的指针,而B对象包含指向char的指针。要从...
    编程 发布于2025-02-06
  • 如何在Java字符串中有效替换多个子字符串?
    如何在Java字符串中有效替换多个子字符串?
    Exploiting Regular ExpressionsA more efficient solution involves leveraging regular expressions.正则表达式允许您定义复杂的搜索模式并在单个操作中执行文本转换。示例示例usage 接下来,您可以使用匹配器...
    编程 发布于2025-02-06
  • 为什么我的nvarchar(最大)值将SQL Server 2005中的4000个字符截断为4000个字符?
    为什么我的nvarchar(最大)值将SQL Server 2005中的4000个字符截断为4000个字符?
    convenation crocess 在提供的代码中,字符串是通过对一系列常量和一系列常数和一系列常数和变量均小于4000个字符。在被分配到 @sql1之前,串联的字符串仍被视为较小字符串的集合。 数据类型preceDence [&& && &&&&&&&&&&&&&&&&&&&&&&&...
    编程 发布于2025-02-06
  • 为什么在JDBC Connections中使用class.forname(“ oracle.jdbc.oracledriver”)?
    为什么在JDBC Connections中使用class.forname(“ oracle.jdbc.oracledriver”)?
    class.forname(“ oracle.jdbc.driver.oracledriver”)在jdbc connections中的目的是什么?使用Java,class.forname(“ oracle.jdbc.driver.oracledriver”)命令扮演至关重要的角色。 的目的是确...
    编程 发布于2025-02-06
  • 如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    如何修复\“常规错误:2006 MySQL Server在插入数据时已经消失\”?
    插入记录时如何解决“一般错误:2006 MySQL 服务器已消失”介绍:将数据插入 MySQL 数据库有时会导致错误“一般错误:2006 MySQL 服务器已消失”。当与服务器的连接丢失时会出现此错误,通常是由于 MySQL 配置中的两个变量之一所致。解决方案:解决此错误的关键是调整wait_tim...
    编程 发布于2025-02-06
  • 在网络开发中保持领先地位:最新新闻,工具和见解#49
    在网络开发中保持领先地位:最新新闻,工具和见解#49
    ?阅读! 创始人模式:一般假设:一家初创公司的管理正在向经理模式变化 - 经理模式 - 在商学院管理和教授的众所周知的方式。 Founder mode is less known and understood, but may be more effective. / start...
    编程 发布于2025-02-06
  • 如何使用PHP将斑点(图像)正确插入MySQL?
    如何使用PHP将斑点(图像)正确插入MySQL?
    在尝试将image存储在mysql数据库中时,您可能会遇到一个可能会遇到问题。本指南将提供成功存储您的图像数据的解决方案。 easudy values('$ this-> image_id','file_get_contents($ tmp_image)...
    编程 发布于2025-02-06
  • 我应该在使用块内明确关闭SQLConnection吗?
    我应该在使用块内明确关闭SQLConnection吗?
    答案在于使用关键字的行为。退出使用块时,在包含的对象上调用.dispose()方法。对于sqlConnection,.dispose()自动关闭连接并发布任何关联的资源。 ]使用cn作为new System.data.sqlclient.sqlConnection() CN.OPEN ...
    编程 发布于2025-02-06
  • 为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    为什么Microsoft Visual C ++无法正确实现两台模板的实例?
    [2明确担心Microsoft Visual C(MSVC)在正确实现两相模板实例化方面努力努力。该机制的哪些具体方面无法按预期运行?背景:说明:的初始Syntax检查在范围中受到限制。它未能检查是否存在声明名称的存在,导致名称缺乏正确的声明时会导致编译问题。为了说明这一点,请考虑以下示例:一个符合...
    编程 发布于2025-02-06
  • 如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    如何从Python中的字符串中删除表情符号:固定常见错误的初学者指南?
    从python 导入编解码器 导入 text = codecs.decode('这狗\ u0001f602'.encode('utf-8'),'utf-8') 印刷(文字)#带有表情符号 emoji_pattern = re.compile(“ [”...
    编程 发布于2025-02-06
  • 在Sqlalchemy中过滤布尔值时,如何处理Flake8警告?
    在Sqlalchemy中过滤布尔值时,如何处理Flake8警告?
    避免使用sqlalchemy滤波器中布尔比较的flake8警告在使用sqlalchemy时,在过滤器条款中使用布尔比较通常是通常的。但是,Flake8在使用“ ==”操作员进行布尔比较时可能会引起警告。 sqlalchemy filter行为,但是,在sqlalchemy filter子句中,“ ...
    编程 发布于2025-02-06

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3