首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Yup dataURI验证

Yup dataURI验证
EN

Stack Overflow用户
提问于 2020-11-26 12:59:32
回答 1查看 2.6K关注 0票数 4

我的表单(React)中有img字段,它可以是linkdataURI

如何与Yup检查在字段中输入的有效值?

现在我用:

代码语言:javascript
复制
const validationSchema = Yup.object().shape({
    img_url: Yup.string().url(),
  });

但是,如果输入dataURI,则会出现错误。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-11-26 15:22:32

无法将模式指定为两种类型中的一种:https://github.com/jquense/yup/issues/321

但是,您可以使用Yup.lazy():https://github.com/jquense/yup/issues/647动态返回模式。如果img_url以' data‘开头,则使用Yup.string().matches()返回数据URI的模式,否则,返回带有Yup.string().url()的url模式

您可以找到关于数据URI regex 这里的要点和讨论。

这个应该能工作:

代码语言:javascript
复制
  const validationSchema = Yup.object().shape({
    img_url: Yup.lazy((value) =>
        /^data/.test(value)
          ? Yup.string()
              .trim()
              .matches(
                /^data:([a-z]+\/[a-z0-9-+.]+(;[a-z-]+=[a-z0-9-]+)?)?(;base64)?,([a-z0-9!$&',()*+;=\-._~:@/?%\s]*)$/i,
                'Must be a valid data URI',
              )
              .required()
          : Yup.string().trim().url('Must be a valid URL').required(),
      ),
  });

注意:我添加了trim(),这样您就可以在URL或img_url的数据URI周围拥有额外的空白空间,从而仍然被认为是有效的。此外,我将img_url设置为必需的,这样如果为空,它就会被视为无效。根据您的用例,您可能希望或不希望这样做。

这里有一个没有trim()或required()的版本:

代码语言:javascript
复制
validationSchema={Yup.object({
      img_url: Yup.lazy((value) =>
        /^data/.test(value)
          ? Yup.string().matches(
              /^data:([a-z]+\/[a-z0-9-+.]+(;[a-z-]+=[a-z0-9-]+)?)?(;base64)?,([a-z0-9!$&',()*+;=\-._~:@/?%\s]*)$/i,
              'Must be a valid data URI',
            )
          : Yup.string().url('Must be a valid URL'),
      )
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65022547

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档