前段时间,阿堂在项目中就要对email进行验正..允许输入多个email,以;来分隔,然后,在页面 表单中提交时,进行验正,是单个邮件还是多个邮件,是否正确.关于是多个邮件,还是单个邮件我就不多说了,是多个时,只需要用split(";")来生成 一个数组,然后循环对每个email判断是否正确的email格式就行了.这不是阿堂要谈论的重点,我这里只想说明一下,我这里要验正的情况..
一般的email,形如[email protected],[email protected]这样一些常用的形式就行了,但是在我们公司的一些客户中邮箱却有一些[email protected],[email protected],[email protected]这 种类似的形式,在@符号之前还有点.,原来是拿来就用,可是现在就不行,得自己研究正则的用法了
朋友们,如有正则表达式方面的问题,欢迎在此留言交流讨论!
原来的正则表达式
/^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/;
我根据我的实际情况修改后的正则表达式
/^(\w)+(\.\w+)*@(\w)+((\.\w{2,3}){1,3})$/;
或者
/^(\w)+(\.\w+)*@(\w)+((\.\w+)+)$/;
字符描述:
^ :匹配输入的开始位置。
\:将下一个字符标记为特殊字符或字面值。
* :匹配前一个字符零次或几次。
+ :匹配前一个字符一次或多次。
(pattern) 与模式匹配并记住匹配。
x|y:匹配 x 或 y。
[a-z] :表示某个范围内的字符。与指定区间内的任何字符匹配。
\w :与任何单词字符匹配,包括下划线。
{n,m} 最少匹配 n 次且最多匹配 m 次
$ :匹配输入的结尾。
附一简单的js
function checkEmail()
{
var emailValue=document. getElementById_r("email").value;
if (!isEmail(emailValue))
{
alert("您输入的邮箱有误,请重新核对后再输入!");
document. getElementById_r("email").focus();
return false;
}
return true;
}
function isEmail(str){
var reg = /^(\w)+(\.\w+)*@(\w)+((\.\w+)+)$/;
return reg.test(str);
}
阿堂也附上了输入多个邮件时的验正方法
//验正邮箱格式要正确 20080602_heyitang
var email=document. getElementById_r("trans_email").value;
//如果,用户入了邮箱才需要进行判断
if (email!=null)
{if (email.indexOf(";")==-1)
{
if(!isEmail(email))
{
alert("您输入的单个邮件格式有误,请重新核对后再输入");
document. getElementById_r("trans_email").focus();
return false;
}
}
else
{
var emailArray=email.split(";");
for(i=0;i
//这里防止出现[email protected];[email protected];;多加了;这时候,数组中可能有元素没有内容
if(emailArray[i]!=null || emailArray[i]!="")
{
if(!isEmail(emailArray[i]))
{
alert("您输入的多个邮箱格式中有邮箱格式不 正确,请重新核对后再输入");
document. getElementById_r("trans_email").focus();
return false;
}
}
}
}
}
身份证正则表达式
/^(\d{15}$|^\d{18}$|^\d{17}(\d|X|x))$/
转自:http://www.cnblogs.com/vs-bug/archive/2010/03/26/1696752.html