首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React Yup模式

React Yup模式
EN

Stack Overflow用户
提问于 2020-12-19 06:59:02
回答 1查看 98关注 0票数 0

我正在使用Yup来验证电子邮件字段:

代码语言:javascript
复制
const Schema = Yup.object().shape({
email: Yup.string()
  .email("non valid email format")
  .required("Email required"),
  ...

在表单提交过程中,我检查电子邮件域是否包含在禁用域名列表中,如果包含,则在弹出窗口中显示错误消息:

代码语言:javascript
复制
const forbidDomains = domains;
const domain = data.email.split("@");
if(forbidDomains.Domains.includes(domain[1])) {
  this.setState({openPopup:true,statusMessage:"domain not allowed : " + domain[1]})
      this.setState({isSubmitting:false})
      return;
}

我想检查Yup模式中的域,但我不确定是否可以。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-12-19 07:07:40

我想你要找的是来自Yup的.test()。也许像这样的东西可能会起作用:

代码语言:javascript
复制
const schema = {
    email: Yup.string()
        .string()
        .email()
        .test('test-name', 'Validation failure message', 
            function(value) {
                // your logic to check the domain
         })
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/65364994

复制
相关文章

相似问题

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