regex 电子 邮件 和 空 字符 串 的 Javascript 正则 表达式 [ 重复 ]

siotufzp  于 2022-11-18  发布在  Java
关注(0)|答案(3)|浏览(86)

此问题在此处已有答案

How can I validate an email address in JavaScript?(79个答案)
七年前就关门了。
此帖子已在14天前编辑并提交审核,未能重新打开:
原始关闭原因未解决
我正在使用这个正则表达式/^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,6}$/来验证电子邮件的格式,但是当我把电子邮件字段留空时,它显示了一个错误,即格式无效。有人能帮助我如何添加一个空字符串的正则表达式吗?

iibxawm4

iibxawm41#

您可以使用OR |运算子搭配^$来比对空字串。
/^[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+.[a-zA-Z]{2,6}$|^$/

xdyibdwo

xdyibdwo2#

^(?:[a-zA-Z0-9._-]+@[a-zA-Z0-9.-]+.[a-zA-Z]{2,6})?$

你可以把所有的都放到一个group中,并使这个组成为可选的。
https://regex101.com/r/mG8kZ9/12

00jrzges

00jrzges3#

几天前我也有同样的需求,所以我为它创建了一个单独的函数,这样它就可以被多个电子邮件字段和其他文本字段使用。
虽然提供的正则表达式是为所有有效的电子邮件,你可以限制根据自己的需要。

function IsValidEmailAddress(selectorElement) {

var emailAddress = $(selectorElement).val();
emailAddress = emailAddress.trim();

//All valid email pattern,a-z,0-9 etc [from stack overflow]
var pattern = new RegExp(/^((([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+(\.([a-z]|\d|[!#\$%&'\*\+\-\/=\?\^_`{\|}~]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])+)*)|((\x22)((((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(([\x01-\x08\x0b\x0c\x0e-\x1f\x7f]|\x21|[\x23-\x5b]|[\x5d-\x7e]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(\\([\x01-\x09\x0b\x0c\x0d-\x7f]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))))*(((\x20|\x09)*(\x0d\x0a))?(\x20|\x09)+)?(\x22)))@((([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|\d|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.)+(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])|(([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])([a-z]|\d|-|\.|_|~|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])*([a-z]|[\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF])))\.?$/i);

//Test the pattern with input emailAddress
if (pattern.test(emailAddress)) {

   //Put your own logic here

    if ($(selectorElement).parent().hasClass('error')) { 
        $(selectorElement).parent().removeClass('error');
    }
    return true;
}

if (!IsNullOrEmptyElement(selectorElement)) {

  //put your own logic here

    $(selectorElement).parent().addClass('error');
    $(selectorElement).val('');
    $(selectorElement).attr("placeholder", "Add Valid Email Address.");
}
return false;
};

//Function checks wether the element is Null or empty
function IsNullOrEmptyElement(selectorElement) {
var textboxText = $(selectorElement).val();

textboxText = textboxText.trim();

if (textboxText == null || textboxText == "") {
    $(selectorElement).parent().addClass('error');
    $(selectorElement).attr("placeholder", "This field is required.");
    return true;
}
$(selectorElement).parent().removeClass('error');
return false;

}

相关问题