正则表达式

许多时候我们在制作表单时需要限制文本框输入内容的类型,下面我们用正则表达式限制文本框只能输入数字、小数点、英文字母、汉字等各类代码。


   1.文本框只能输入数字代码(小数点也不能输入)
    <input onkeyup="this.value=this.value.replace(/\D/g,'')" onafterpaste="this.value=this.value.replace(/\D/g,'')">

   2.只能输入数字,能输小数点.
    <input onkeyup="if(isNaN(value))execCommand('undo')" onafterpaste="if(isNaN(value))execCommand('undo')">
    <input name=txt1 onchange="if(/\D/.test(this.value)){alert('只能输入数字');this.value='';}">

   3.数字和小数点方法二
    <input type=text t_value="" o_value="" onkeypress="if(!this.value.match(/^[\+\-]?\d*?\.?\d*?$/))this.value=this.t_value;else this.t_value=this.value;if(this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/))this.o_value=this.value" onkeyup="if(!this.value.match(/^[\+\-]?\d*?\.?\d*?$/))this.value=this.t_value;else this.t_value=this.value;if(this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/))this.o_value=this.value" onblur="if(!this.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?|\.\d*?)?$/))this.value=this.o_value;else{if(this.value.match(/^\.\d+$/))this.value=0+this.value;if(this.value.match(/^\.$/))this.value=0;this.o_value=this.value}">

可以封装成单独的函数

 function keyPress(ob) {
            if (!ob.value.match(/^[\+\-]?\d*?\.?\d*?$/)) ob.value = ob.t_value; else ob.t_value = ob.value; if (ob.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/)) ob.o_value = ob.value;
        }
        function keyUp(ob) {
            if (!ob.value.match(/^[\+\-]?\d*?\.?\d*?$/)) ob.value = ob.t_value; else ob.t_value = ob.value; if (ob.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?)?$/)) ob.o_value = ob.value;
        }
        function onBlur(ob) {
         if(!ob.value.match(/^(?:[\+\-]?\d+(?:\.\d+)?|\.\d*?)?$/))ob.value=ob.o_value;else{if(ob.value.match(/^\.\d+$/))ob.value=0+ob.value;if(ob.value.match(/^\.$/))ob.value=0;ob.o_value=ob.value};
        }

只需在调用,传入this对象即可!

   4.只能输入字母和汉字
    <input onkeyup="value=value.replace(/[\d]/g,'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[\d]/g,''))" maxlength=10 name="Numbers">

   5.只能输入英文字母和数字,不能输入中文
    <input onkeyup="value=value.replace(/[^\w\.\/]/ig,'')">

   6.只能输入数字和英文
    <input onKeyUp="value=value.replace(/[^\d|chun]/g,'')">

    7.小数点后只能有最多两位(数字,中文都可输入),不能输入字母和运算符号:
    <input onKeyPress="if((event.keyCode<48 || event.keyCode>57) && event.keyCode!=46 || /\.\d\d$/.test(value))event.returnValue=false">

    8.小数点后只能有最多两位(数字,字母,中文都可输入),可以输入运算符号:
    <input onkeyup="this.value=this.value.replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3')">

 

 

JavaScript表单验证年龄 
JavaScript表单验证年龄,判断一个输入量是否符合年龄,通过正则表达式实现。 
Javascript代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
//检查年龄   
  
function isAge(str){   
  
var mydate=new Date;   
  
var now=mydate.getFullYear();   
  
if (str < now-60 || str > now-18){   
  
return false;   
  
}   
  
return true;   
  
}  

//检查年龄    function isAge(str){    var mydate=new Date;    var now=mydate.getFullYear();    if (str < now-60 || str > now-18){    return false;    }    return true;    }


Javascript代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
JavaScript表单验证电话号码,判断一个输入量是否为电话号码,通过正则表达式实现。   
//检查电话号码   
function isTel(str){   
       var reg=/^([0-9]|[\-])+$/g ;   
       if(str.length<7 || str.length>18){   
        return false;   
       }   
       else{   
         return reg.exec(str);   
       }   
}  

JavaScript表单验证电话号码,判断一个输入量是否为电话号码,通过正则表达式实现。  //检查电话号码  function isTel(str){         var reg=/^([0-9]|[\-])+$/g ;         if(str.length<7 || str.length>18){          return false;         }         else{           return reg.exec(str);         }  }


JavaScript表单验证email,判断一个输入量是否为邮箱email,通过正则表达式实现。 
Javascript代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
//检查email邮箱   
function isEmail(str){   
       var reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/;   
       return reg.test(str);   
}  

//检查email邮箱  function isEmail(str){         var reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/;         return reg.test(str);  }  


JavaScript表单验证中文大写字母,判断一个输入量是否为中文或大写的英文字母,通过正则表达式实现。 
Javascript代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
// 检查是否为有效的真实姓名,只能含有中文或大写的英文字母   
function isValidTrueName(strName){   
      var str = Trim(strName);   //判断是否为全英文大写或全中文,可以包含空格   
      var reg = /^[A-Z u4E00-u9FA5]+$/;   
      if(reg.test(str)){   
       return false;   
      }   
      return true;   
}  

// 检查是否为有效的真实姓名,只能含有中文或大写的英文字母  function isValidTrueName(strName){        var str = Trim(strName);   //判断是否为全英文大写或全中文,可以包含空格        var reg = /^[A-Z u4E00-u9FA5]+$/;        if(reg.test(str)){         return false;        }        return true;  }


JavaScript正则比较两个字符串, 
就是利用正则表达式快速比较两个字符串的不同字符。 
Java代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
<script language="JavaScript">   
var str1 = "求一个比较字符串处理功能";   
var str2 = "求两或三个比较字符串处理";   
var re = new RegExp("(?=.*?)[^" + str1 +"](?=.*?)|(?=.*?)[^" + str2 + "](?=.*?)", "g");   
var arr;   
while ((arr = re.exec(str1 + str2)) != null)   
{   
   document.write(arr);   
}   
</script>  

<script language="JavaScript">  var str1 = "求一个比较字符串处理功能";  var str2 = "求两或三个比较字符串处理";  var re = new RegExp("(?=.*?)[^" + str1 +"](?=.*?)|(?=.*?)[^" + str2 + "](?=.*?)", "g");  var arr;  while ((arr = re.exec(str1 + str2)) != null)  {     document.write(arr);  }  </script>


JavaScript表单验证密码是检查输入框是否为有效的密码, 
密码只允许由ascii组成, 
此函数只在修改或注册密码时使用。 
也就是说一切不是ascii组成的字符串都不能通过验证。 
具体函数checkValidPasswd请看下面的演示代码 
Java代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
function checkValidPasswd(str){   
      var reg = /^[x00-x7f]+$/;   
      if (! reg.test(str)){   
       return false;   
      }   
      if (str.length < 6 || str.length > 16){   
       return false;   
      }   
      return true;   
}  

    function checkValidPasswd(str){            var reg = /^[x00-x7f]+$/;            if (! reg.test(str)){             return false;            }            if (str.length < 6 || str.length > 16){             return false;            }            return true;      }


JavaScript正则验证检查输入对象的值是否符合整数格式 
输入量是str 输入的字符串 
如果输入量字符串str通过验证返回true,否则返回false 
Java代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
function isInteger( str ){   
var regu = /^[-]{0,1}[0-9]{1,}$/;   
return regu.test(str);   
}  

    function isInteger( str ){      var regu = /^[-]{0,1}[0-9]{1,}$/;      return regu.test(str);      }


JavaScript正则验证字符串是否为空 
用途:检查输入字符串是否为空或者全部都是空格 
输入量是一个字符串:str 
返回:如果输入量全是空返回true,否则返回false 
Java代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
function isNull( str ){   
if ( str == "" ) return true;   
var regu = "^[ ]+$";   
var re = new RegExp(regu);   
return re.test(str);   
}  

    function isNull( str ){      if ( str == "" ) return true;      var regu = "^[ ]+$";      var re = new RegExp(regu);      return re.test(str);      }


JavaScript正则验证IP,用途:校验ip地址的格式 
输入:strIP:ip地址 
返回:如果JavaScript通过验证IP返回true,否则返回false; 
JavaScript验证IP代码如下 
Java代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
function isIP(strIP) {   
if (isNull(strIP)) return false;   
var re=/^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g //匹配IP地址的正则表达式   
if(re.test(strIP))   
{   
if( RegExp.$1 <256 && RegExp.$2<256 && RegExp.$3<256 && RegExp.$4<256) return true;   
}   
return false;   
}  

    function isIP(strIP) {      if (isNull(strIP)) return false;      var re=/^(\d+)\.(\d+)\.(\d+)\.(\d+)$/g //匹配IP地址的正则表达式      if(re.test(strIP))      {      if( RegExp.$1 <256 && RegExp.$2<256 && RegExp.$3<256 && RegExp.$4<256) return true;      }      return false;      }


JavaScript表单验证自定义内容,这个比较好,可以自由定制输入项的内容来用JavaScript进行验证,下面demo中是表单项只能为数字和"_",同样您可以进行扩展来达到您想要的目的。用于电话/银行帐号验证上,可扩展到域名注册等 
Java代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
<script  language="javascript">   
<!--   
function  isNumber(String)   
{     
var  Letters  =  "1234567890-";  //可以自己增加可输入值   
var  i;   
var  c;   
if(String.charAt(  0  )=='-')   
return  false;   
if(  String.charAt(  String.length  -  1  )  ==  '-'  )   
return  false;   
for(  i  =  0;  i  <  String.length;  i  ++  )   
{     
c  =  String.charAt(  i  );   
if  (Letters.indexOf(  c  )  <  0)   
return  false;   
}   
return  true;   
}   
function  CheckForm()   
{     
if(!  isNumber(document.form.TEL.value))  {     
alert("您的电话号码不合法!");   
document.form.TEL.focus();   
return  false;   
}   
return  true;   
}   
-->   
</script>  

<script  language="javascript">  <!--  function  isNumber(String)  {    var  Letters  =  "1234567890-";  //可以自己增加可输入值  var  i;  var  c;  if(String.charAt(  0  )=='-')  return  false;  if(  String.charAt(  String.length  -  1  )  ==  '-'  )  return  false;  for(  i  =  0;  i  <  String.length;  i  ++  )  {    c  =  String.charAt(  i  );  if  (Letters.indexOf(  c  )  <  0)  return  false;  }  return  true;  }  function  CheckForm()  {    if(!  isNumber(document.form.TEL.value))  {    alert("您的电话号码不合法!");  document.form.TEL.focus();  return  false;  }  return  true;  }  -->  </script>


判断手机号是否正确 
Java代码 复制代码 收藏代码正则表达式限制文本框只能输入数字 - 饮冰 - 饮冰
function regIsPhone(fData)   
{   
    var reg = /^(\+86)?(1[0-9]{10})$/;   
    return reg.test(fData);   
}   

        function regIsPhone(fData)          {              var reg = /^(\+86)?(1[0-9]{10})$/;              return reg.test(fData);          } 


JavaScript验证正则表达式大全,搜集最全的JavaScript验证正则表达式,开始查看吧,这里的都是正则表达式的例子,具体和函数结合的使用方法,还请查看下篇文章《JavaScript使用正则表达式进行验证》 
匹配中文字符的正则表达式: [u4e00-u9fa5] 
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了 
匹配双字节字符(包括汉字在内):[^x00-xff] 
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1) 
匹配空白行的正则表达式:ns*r 
评注:可以用来删除空白行 
匹配HTML标记的正则表达式:< (S*?)[^>]*>.*?|< .*? /> 
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力 
匹配首尾空白字符的正则表达式:^s*|s*$ 
评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式 
匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)* 
评注:表单验证时很实用 
匹配网址URL的正则表达式:[a-zA-z]+://[^s]* 
评注:网上流传的版本功能很有限,上面这个基本可以满足需求 
匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$ 
评注:表单验证时很实用 
匹配国内电话号码:d{3}-d{8}|d{4}-d{7} 
评注:匹配形式如 0511-4405222 或 021-87888822 
匹配腾讯QQ号:[1-9][0-9]{4,} 
评注:腾讯QQ号从10000开始 
匹配中国邮政编码:[1-9]d{5}(?!d) 
评注:中国邮政编码为6位数字 
匹配身份证:d{15}|d{18} 
评注:中国的身份证为15位或18位 
匹配ip地址:d+.d+.d+.d+ 
评注:提取ip地址时有用 
匹配特定数字: 
^[1-9]d*$    //匹配正整数 
^-[1-9]d*$   //匹配负整数 
^-?[1-9]d*$   //匹配整数 
^[1-9]d*|0$  //匹配非负整数(正整数 + 0) 
^-[1-9]d*|0$   //匹配非正整数(负整数 + 0) 
^[1-9]d*.d*|0.d*[1-9]d*$   //匹配正浮点数 
^-([1-9]d*.d*|0.d*[1-9]d*)$  //匹配负浮点数 
^-?([1-9]d*.d*|0.d*[1-9]d*|0?.0+|0)$  //匹配浮点数 
^[1-9]d*.d*|0.d*[1-9]d*|0?.0+|0$   //匹配非负浮点数(正浮点数 + 0) 
^(-([1-9]d*.d*|0.d*[1-9]d*))|0?.0+|0$  //匹配非正浮点数(负浮点数 + 0) 
评注:处理大量数据时有用,具体应用时注意修正 
匹配特定字符串: 
^[A-Za-z]+$  //匹配由26个英文字母组成的字符串 
^[A-Z]+$  //匹配由26个英文字母的大写组成的字符串 
^[a-z]+$  //匹配由26个英文字母的小写组成的字符串 
^[A-Za-z0-9]+$  //匹配由数字和26个英文字母组成的字符串 
^w+$  //匹配由数字、26个英文字母或者下划线组成的字符串 
在使用RegularExpressionValidator验证控件时的验证功能及其验证表达式介绍如下: 
只能输入数字:“^[0-9]*$” 
只能输入n位的数字:“^d{n}$” 
只能输入至少n位数字:“^d{n,}$” 
只能输入m-n位的数字:“^d{m,n}$” 
只能输入零和非零开头的数字:“^(0|[1-9][0-9]*)$” 
只能输入有两位小数的正实数:“^[0-9]+(.[0-9]{2})?$” 
只能输入有1-3位小数的正实数:“^[0-9]+(.[0-9]{1,3})?$” 
只能输入非零的正整数:“^+?[1-9][0-9]*$” 
只能输入非零的负整数:“^-[1-9][0-9]*$” 
只能输入长度为3的字符:“^.{3}$” 
只能输入由26个英文字母组成的字符串:“^[A-Za-z]+$” 
只能输入由26个大写英文字母组成的字符串:“^[A-Z]+$” 
只能输入由26个小写英文字母组成的字符串:“^[a-z]+$” 
只能输入由数字和26个英文字母组成的字符串:“^[A-Za-z0-9]+$” 
只能输入由数字、26个英文字母或者下划线组成的字符串:“^w+$” 
验证用户密码:“^[a-zA-Z]w{5,17}$”正确格式为:以字母开头,长度在6-18之间, 
只能包含字符、数字和下划线。 
验证是否含有^%&',;=?$"等字符:“[^%&',;=?$x22]+” 
只能输入汉字:“^[u4e00-u9fa5],{0,}$” 
验证Email地址:“^w+[-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*$” 
验证InternetURL:“^http://([w-]+.)+[w-]+(/[w-./?%&=]*)?$” 
验证电话号码:“^((d{3,4})|d{3,4}-)?d{7,8}$” 
正确格式为:“XXXX-XXXXXXX”,“XXXX-XXXXXXXX”,“XXX-XXXXXXX”, 
“XXX-XXXXXXXX”,“XXXXXXX”,“XXXXXXXX”。 
验证身份证号(15位或18位数字):“^d{15}|d{}18$” 
验证一年的12个月:“^(0?[1-9]|1[0-2])$”正确格式为:“01”-“09”和“1”“12” 
验证一个月的31天:“^((0?[1-9])|((1|2)[0-9])|30|31)$” 
正确格式为:“01”“09”和“1”“31”。 
匹配中文字符的正则表达式: [u4e00-u9fa5] 
匹配双字节字符(包括汉字在内):[^x00-xff] 
匹配空行的正则表达式:n[s| ]*r 
匹配HTML标记的正则表达式:/< (.*)>.*|< (.*) />/ 
匹配首尾空格的正则表达式:(^s*)|(s*$) 
匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)* 
匹配网址URL的正则表达式:http://([w-]+.)+[w-]+(/[w- ./?%&=]*)? 
(1)应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1) 
String.prototype.len=function(){return this.replace([^x00-xff]/g,"aa").length;} 
(2)应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现 
String.prototype.trim = function() 

return this.replace(/(^s*)|(s*$)/g, ""); 

(3)应用:利用正则表达式分解和转换IP地址 
function IP2V(ip) //IP地址转换成对应数值 

re=/(d+).(d+).(d+).(d+)/g //匹配IP地址的正则表达式 
if(re.test(ip)) 

return RegExp.$1*Math.pow(255,3))+RegExp.$2*Math.pow(255,2))+RegExp.$3*255+RegExp.$4*1 

else 

throw new Error("Not a valid IP address!") 


(4)应用:从URL地址中提取文件名的javascript程序 
s="http://www.9499.net/page1.htm"; 
s=s.replace(/(.*/){0,}([^.]+).*/ig,"$2") ; //Page1.htm 
(5)应用:利用正则表达式限制网页表单里的文本框输入内容 
用正则表达式限制只能输入中文:οnkeyup="value="/blog/value.replace(/["^u4E00-u9FA5] /g,'') " onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^u4E00-u9FA5]/g,''))" 
用正则表达式限制只能输入全角字符: οnkeyup="value="/blog/value.replace(/["^uFF00-uFFFF]/g,'') " onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^uFF00-uFFFF]/g,''))" 
用正则表达式限制只能输入数字:οnkeyup="value="/blog/value.replace(/["^d]/g,'') "onbeforepaste= "clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,''))" 
用正则表达式限制只能输入数字和英文:οnkeyup="value="/blog/value.replace(/[W]/g,"'') "onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^d]/g,'' 

 

1.非负整数         /^\d+$/
     2.正整数           /^[0-9]*[1-9][0-9]*$/
     3.非正整数       /^((-\d+)|(0+))$/
4.负整数 /^-[0-9]*[1-9][0-9]*$/
     5.整数               /^-?\d+$/
     6.非负浮点数     /^\d+(\.\d+)?$/
     7.正浮点数       /^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$/
     8.非正浮点数     /^((-\d+(\.\d+)?)|(0+(\.0+)?))$/
     9.负浮点数         /^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$/
     10.浮点数         /^(-?\d+)(\.\d+)?$/
     11.数字             /^\d+(\.{1}\d+)?$/
     12.由26个英文字母组成的字符串                     /^[A-Za-z]+$/
     13.由26个英文字母的大写组成的字符串           /^[A-Z]+$/
     14.由26个英文字母的小写组成的字符串           /^[a-z]+$/
     15.由数字和26个英文字母组成的字符串           /^[A-Za-z0-9]+$/
     16.由数字、26个英文字母或者下划线组成的字符串             /^\w+$/
     17.匹配所有单字节长度的字符组成的字符串                       /^[\x00-\xff]+$/
     18.匹配所有双字节长度的字符组成的字符串                       /^[^\x00-\xff]+$/
     19.字符串是否含有双字节字                                                 /[^\x00-\xff]+/
     20.email地址             /^[\w-]+(\.[\w-]+)*@[\w-]+(\.[\w-]+)+$/
         或者                     /w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*/
     21.url地址                 /^[a-zA-z]+://(\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?$/
         或者                     /http://([w-]+.)+[w-]+(/[w- ./?%&=]*)?/
     22.匹配中文字符的正则             /[u4e00-u9fa5]/
     23.匹配双字节字符(包括汉字在内)             /[^x00-xff]/
         应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
             String.prototype.len=function(){
                 return this.replace([^x00-xff]/g,”aa”).length;
             }
     24.匹配空行的正则             /n[s| ]*r/
     25.匹配HTML标记的正则             /<(.*)>.*</1>|<(.*) />/
     26.匹配首尾空格的正则               /(^s*)|(s*$)/
         应用:javascript中没有像vbscript那样的trim函数,我们就可以利用这个表达式来实现,如下:
             String.prototype.trim = function(){
                 return this.replace(/(^s*)|(s*$)/g, “”);
             }
     27.匹配IP地址的正则             /(d+).(d+).(d+).(d+)/
         应用:利用正则表达式匹配IP地址,并将IP地址转换成对应数值的Javascript程序:
             function IP2V(ip){
                 re=/(d+).(d+).(d+).(d+)/g;
                 if(re.test(ip)){
                     return RegExp.$1*Math.pow(255,3))+
                     RegExp.$2*Math.pow(255,2))+
                     RegExp.$3*255+RegExp.$4*1;
                 }
                 else{
                     throw new Error(“Not a valid IP address!”);
                 }
             }
         其实直接用split函数来分解可能更简单,程序如下:
             var ip=”10.100.20.168″;
             ip=ip.split(“.”);
             alert(“IP值是:”+(ip[0]*255*255*255+ip[1]*255*255+ip[2]*255+ip[3]*1));
     28.去除字串中重复的字符的javascript程序
         var s=”abacabefgeeii”;
         var s1=s.replace(/(.).*1/g,”$1″);
         var re=new RegExp(“["+s1+"]“,”g”);
         var s2=s.replace(re,”");
         alert(s1+s2);                     //结果为:abcefgi
     /*使用后向引用取出包括重复的字符,再以重复的字符建立第二个表达式,取到不重复的字符,
       两者串连。这个方法对于字符顺序有要求的字符串可能不适用。*/
     29.用正则表达式从URL地址中提取文件名的javascript程序
         s=”http://www.9499.net/page1.htm“;
         s=s.replace(/(.*/){0,}([^.]+).*/ig,”$2″);
         alert(s);                             //结果为page1
     30.限制表单文本框输入内容
         只能输入中文:
             οnkeyup=”value=value.replace(/[^u4E00-u9FA5]/g,”)”
                 onbeforepaste=”clipboardData.setData(‘text’,
                 clipboardData.getData(‘text’).replace(/[^u4E00-u9FA5]/g,”))”
         只能输入全角字符:
             οnkeyup=”value=value.replace(/[^uFF00-uFFFF]/g,”)”
                 onbeforepaste=”clipboardData.setData(‘text’,
                 clipboardData.getData(‘text’).replace(/[^uFF00-uFFFF]/g,”))”
         只能输入数字:
             οnkeyup=”value=value.replace(/[^d]/g,”)”
                 onbeforepaste=”clipboardData.setData(‘text’,
                 clipboardData.getData(‘text’).replace(/[^d]/g,”))”
         只能输入数字和英文:
             οnkeyup=”value=value.replace(/[W]/g,”)”
                 onbeforepaste=”clipboardData.setData(‘text’,
                 clipboardData.getData(‘text’).replace(/[^d]/g,”))”
     31.验证文件名由字母,数字,下滑线组成                 /^((\w+)(\.{1})(\w+))$/
     32.匹配日期(1900-1999)
         /^19\d{2}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1])))$/
     33.匹配日期(2000-2999)
         /^20\d{2}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1])))$/
     34.匹配日期时间
         /^(1|2\d{3}-((0[1-9])|(1[0-2]))-((0[1-9])|([1-2][0-9])|(3([0|1]))))( (\d{2}):(\d{2}):(\d{2}))?$/
网页验证的例子:
<SCRIPT language=”javascript”><!–
         function validate(){
                 var frm = document.form1;
                 if ( frm.orgname.value==”" ){
                         alert(“机构名称必须填写,请输入!”);
                         frm.orgname.focus();
                         return false;
                 }
                 if ( frm.orgfunction.value==”" ){
                         alert(“机构职能必须填写,请输入!”);
                         frm.orgfunction.focus();
                         return false;
                 }
                 if ( frm.orgpostcode.value==”" ){…}
                 else{
                         var pattern=/^d…{6}$/;
                         if(pattern.test(frm.orgpostcode.value)){…}
                         else{
                             alert(“输入的邮政编码不是合法的格式!”);
                             frm.orgpostcode.focus();
                             return false;
                         }
                 }
                 if ( frm.orgphone.value==”" ){…}
                 else{
                         var str=frm.orgphone.value;
                         var reg=/(^[0-9]…{3,4}-[0-9]…{3,8}$)|(^[0-9]…{3,8}$)|(^([0-9]…{3,4})[0-9]…{3,8}$)|(^0…{0,1}13[0-9]…{9}$)/;
                         if (isNaN(str)){
                                 if(reg.test(str)==false){
                                         alert(“电话号码输入有误,请重新输入!”);
                                         frm.orgphone.value=”";
                                         frm.orgphone.focus();
                                         return false;
                                 }
                         }
                         else if(str.length<6){
                                 alert(“电话输入有误,请重新输入!”);
                                 frm.orgphone.focus();
                                 return false;
                         }
                 }
                 if ( frm.orgfax.value==”" ){…}
                 else{
                         var str=frm.orgfax.value;
                         var reg=/(^[0-9]…{3,4}-[0-9]…{3,8}$)|(^[0-9]…{3,8}$)|(^([0-9]…{3,4})[0-9]…{3,8}$)|(^0…{0,1}13[0-9]…{9}$)/;
                         if (isNaN(str)){
                                 if(reg.test(str)==false){
                                         alert(“传真输入有误,请重新输入!”);
                                         frm.orgfax.value=”";
                                         frm.orgfax.focus();
                                         return false;
                                 }
                         }
                         else if(str.length<6){
                                 alert(“传真输入有误,请重新输入!”);
                                 frm.orgfax.focus();
                                 return false;
                         }
                 }
                 if ( frm.orgemail.value==”" ){…}
                 else{
                         var pattern=/^w+((-w+)|(.w+))*@[A-Za-z0-9]+((.|-)[A-Za-z0-9]+)*.[A-Za-z0-9]+$/;
                         if(pattern.test(frm.orgemail.value)){…}
                         else{
                                 alert(“输入的电子邮箱不是合法的格式!”);
                                 frm.orgemail.focus();
                                 return false;
                         }
                 }
                 if ( frm.orgurl.value==”" ){…}
                 else{
                         var pattern=new RegExp(“((^http)|(^https)|(^ftp))://(\w)+.(\w)+”);
                         if(pattern.test(frm.orgurl.value)){…}
                         else{
                                 alert(“输入的URL不是合法的格式!”);
                                 frm.orgurl.focus();
                                 return false;
                         }
                 }
         }
//–></SCRIPT>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值