觉得比较好的相关JS验证正则
//电子邮件
"^([a-z0-9A-Z]+[-|\\.]?)+[a-z0-9A-Z]@([a-z0-9A-Z]+(-[a-z0-9A-Z]+)?\\.)+[a-zA-Z]{2,}$";
"^[0-9a-z][a-z0-9\._-]{1,}@[a-z0-9-]{1,}[a-z0-9]\.[a-z\.]{1,}[a-z]$"
/* 电话号码
"^(13[4,5,6,7,8,9]|15[0,8,9,1,7]|188|187)\\d{8}$"
时间
"^\[0-2]{1}\[0-6]{1}:\[0-5]{1}\[0-9]{1}:\[0-5]{1}\[0-9]{1}"
原来的正则表达式 /^[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<emailArray.length;i++) { //这里防止出现[email protected];[email protected];;多加了;这时候,数组中可能有元素没有内容 if(emailArray[i]!=null || emailArray[i]!="") { if(!isEmail(emailArray[i])) { alert("您输入的多个邮箱格式中有邮箱格式不 正确,请重新核对后再输入"); document. getElementById_r("trans_email").focus(); return false; } } } } }
去除字符串两端空格的处理
如果采用传统的方式,就要可能就要采用下面的方式了
//清除左边空格
functionjs_ltrim(deststr)
{
if(deststr==null)return"";
varpos=0;
varretStr=newString(deststr);
if(retStr.lenght==0)returnretStr;
while(retStr.substring(pos,pos+1)=="")pos++;
retStr=retStr.substring(pos);
return(retStr);
}
//清除右边空格
functionjs_rtrim(deststr)
{
if(deststr==null)return"";
varretStr=newString(deststr);
varpos=retStr.length;
if(pos==0)returnretStr;
while(pos&&retStr.substring(pos-1,pos)=="")pos--;
retStr=retStr.substring(0,pos);
return(retStr);
}
//清除左边和右边空格
functionjs_trim(deststr)
{
if(deststr==null)return"";
varretStr=newString(deststr);
varpos=retStr.length;
if(pos==0)returnretStr;
retStr=js_ltrim(retStr);
retStr=js_rtrim(retStr);
returnretStr;
}采用正则表达式,来去除两边的空格,只需以下代码
String.prototype.trim=function()
{
returnthis.replace(/(^\s*)|(\s*$)/g,"");
}一句就搞定了,可见正则表达式为我们节省了相当的编写代码量
! 移动手机号的校验
如果采用传统的校验方式至少就要完成下面三步的校验,
(1).是否是数字
(2).是否是11位
(3).数字的第三位是否是5,6,7,8,9
如果采用正则表达式校验,只需以下代码
functioncheckMobile1(form)
{
if(form.mobile.value>"")
{
varreg=/13[5,6,7,8,9]\d{8}/;
if(form.mobile.value.match(reg)==null)
{
alert("请输入正确的移动手机号码!");
form.mobile.focus();returnfalse;
}
}
returntrue;
}从上面的代码可以看出校验移动手机号只需定义一个varreg=/13[5,6,7,8,9]\d{8}/;模式匹配串就可以完成合法性校验了
! URL的校验,条件:必须以http:// 或 https:// 开头, 端口号必须为在1-65535 之间, 以下代码完成了合法性校验
//obj:数据对象
//dispStr:失败提示内容显示字符串
functioncheckUrlValid(obj,dispStr)
{
if(obj==null)
{
alert("传入对象为空");
returnfalse;
}
var str = obj.value;var urlpatern0 =/^https?:\/\/.+$/i;
if(!urlpatern0.test(str))
{
alert(dispStr+"不合法:必须以'http:\/\/'或'https:\/\/'开头!");
obj.focus();
returnfalse;
}var urlpatern2=/^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?.+$/i;
if(!urlpatern2.test(str))
{
alert(dispStr+"端口号必须为数字且应在1-65535之间!");
obj.focus();
returnfalse;
}var urlpatern1=/^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-zA-Z0-9_-](\?)?)*)*$/i;
if(!urlpatern1.test(str))
{
alert(dispStr+"不合法,请检查!");
obj.focus();
returnfalse;
}var s ="0";
vart=0;
varre=newRegExp(":\\d+","ig");
while((arr=re.exec(str))!=null)
{
s = str.substring(RegExp.index+1,RegExp.lastIndex);if(s.substring(0,1)=="0")
{
alert(dispStr+"端口号不能以0开头!");
obj.focus();
returnfalse;
}t = parseInt(s);
if(t<1||t>65535)
{
alert(dispStr+"端口号必须为数字且应在1-65535之间!");
obj.focus();
returnfalse;
}
}
returntrue;
}
对url 的校验,看上去有很多的代码,这是因为要给予出错提示, 否则只需var urlpatern1=/^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-zA-Z0-9_-](\?)?)*)*$/i;一句就可以校验出url合法性了javascript正则表达式检验
/*********************************************************************************
*EO_JSLib.js
*javascript正则表达式检验
**********************************************************************************///校验是否全由数字组成
functionisDigit(s)
{
varpatrn=/^[0-9]{1,20}$/;
if(!patrn.exec(s))returnfalse
returntrue
}//校验登录名:只能输入5-20个以字母开头、可带数字、“_”、“.”的字串
functionisRegisterUserName(s)
{
varpatrn=/^[a-zA-Z]{1}([a-zA-Z0-9]|[._]){4,19}$/;
if(!patrn.exec(s))returnfalse
returntrue
}//校验用户姓名:只能输入1-30个以字母开头的字串
functionisTrueName(s)
{
varpatrn=/^[a-zA-Z]{1,30}$/;
if(!patrn.exec(s))returnfalse
returntrue
}//校验密码:只能输入6-20个字母、数字、下划线
functionisPasswd(s)
{
varpatrn=/^(\w){6,20}$/;
if(!patrn.exec(s))returnfalse
returntrue
}//校验普通电话、传真号码:可以“+”开头,除数字外,可含有“-”
functionisTel(s)
{
//varpatrn=/^[+]{0,1}(\d){1,3}[]?([-]?(\d){1,12})+$/;
varpatrn=/^[+]{0,1}(\d){1,3}[]?([-]?((\d)|[]){1,12})+$/;
if(!patrn.exec(s))returnfalse
returntrue
}//校验手机号码:必须以数字开头,除数字外,可含有“-”
functionisMobil(s)
{
varpatrn=/^[+]{0,1}(\d){1,3}[]?([-]?((\d)|[]){1,12})+$/;
if(!patrn.exec(s))returnfalse
returntrue
}//校验邮政编码
functionisPostalCode(s)
{
//varpatrn=/^[a-zA-Z0-9]{3,12}$/;
varpatrn=/^[a-zA-Z0-9]{3,12}$/;
if(!patrn.exec(s))returnfalse
returntrue
}//校验搜索关键字
functionisSearch(s)
{
varpatrn=/^[^`~!@#$%^&*()+=|\\\][\]\{\}:;'\,.<>/?]{1}[^`~!@$%^&()+=|\\\][\]\{\}:;'\,.<>?]{0,19}$/;
if(!patrn.exec(s))returnfalse
returntrue
}function isIP(s) //byzergling
{
varpatrn=/^[0-9.]{1,20}$/;
if(!patrn.exec(s))returnfalse
returntrue
}