觉得比较好的相关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

}

相关推荐