js的常用正则表达式

1.在input框中只能输入金额,其实就是只能输入最多有两位小数的数字

1 //第一种在input输入框限制 
2  <input type="text" maxlength="8" class="form-control" id="amount" style="margin-right: 2px;" value="" onChange="count();" onkeyup="if (this.value==this.value2) return; if (this.value.search(/^\d*(?:\.\d{0,2})?$/)==-1) this.value=(this.value2)?this.value2:'';else this.value2=this.value;">3 //第二种对于表单动态增加的方式,只能在js方法中验证。 
4  var amount=$("#amount").val(); 
5  if (amount.search(/^\d*(?:\.\d{0,2})?$/)==-1) { 
6    alert("金额格式不对,最多有两位小数"); 
7    return false; 
8 }

2.验证邮箱格式

1 var reg=/\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/; 
2  var email=$("#email").val(); 
3  if(!reg.test(email) ){ 
4     alert("请输入符合规范的邮箱账号!"); 
5     return false; 
6    } 

3.密码采用数字、字母、特殊字符且长度为8-20位 

1 function validatePwd(str) { 
2 if (/^.*?[\d]+.*$/.test(str) && /^.*?[A-Za-z]/.test(str) 
3 && /^.*?[~/`!@#$%^&*()_+|{}?;:><\-\]\\[\/].*$/.test(str) && /^.{8,20}$/.test(str)) { 
4 return true; 
5 } 
6 return false; 
7 } 

4.验证电话号码

 1 /** 
 2  * 验证电话号码 
 3  * @param phoneValue 要验证的电话号码 
 4  * @returns 匹配返回true 不匹配返回false 
 5  */
 6 function validatePhone(phoneValue) { 
 7  phoneValue = valueTrim(phoneValue); 
 8  var reg = /^[1][0-9]{10}$/; 
 9  return reg.test(phoneValue); 
10 } 

5.判断是否是汉字

 1 /** 
 2  * 判断是否是汉字 
 3  * 
 4  * @param charValue 
 5  *   要验证的数据 
 6  * @returns 匹配返回true 不匹配返回false 
 7  */
 8 function isCharacter(charValue) { 
 9  var reg = /^[\u4e00-\u9fa5]{0,}$/; 
10  return reg.test(charValue); 
11 } 

6.是否为字母:true:是,false:不是

1 function isChar(charValue){ 
2  var charPattern=/^[a-zA-Z]*$/; //是否为字母 
3  result=charPattern.test(charValue); 
4  return result; 
5 } 

7.判断是否为数字

1 function isNum(numValue){ 
2  var numPattern=/^\d*$/; //数字的正则表达式 
3  result=numPattern.test(numValue); 
4  return result; 
5 } 

8.整数的正则表达式

1 function isInt(intValue){ 
2   var intPattern=/^0$|^[1-9]\d*$/; //整数的正则表达式 
3  result=intPattern.test(intValue); 
4   return result; 
5  } 

9.是否为字母和数字

1 function isCharNum(flagValue){ 
2  var flagPattern=/^[a-zA-Z0-9]*$/; //是否为字母和数字 
3  result=flagPattern.test(flagValue); 
4  return result; 
5 } 

10.检验18位身份证号码

 1 /** 
 2  * 检验18位身份证号码(15位号码可以只检测生日是否正确即可,自行解决) 
 3  * 
 4  * @param idCardValue 
 5  *   18位身份证号 
 6  * @returns 匹配返回true 不匹配返回false 
 7  */
 8 function idCardVildate(cid) { 
 9 var arrExp = [ 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 ];// 加权因子 
10 var arrValid = [ 1, 0, "X", 9, 8, 7, 6, 5, 4, 3, 2 ];// 校验码 
11 var reg = /^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/; 
12 if (reg.test(cid)) { 
13 var sum = 0, idx; 
14 for (var i = 0; i < cid.length - 1; i++) { 
15 // 对前17位数字与权值乘积求和 
16 sum += parseInt(cid.substr(i, 1), 10) * arrExp[i]; 
17 } 
18 // 计算模(固定算法) 
19 idx = sum % 11; 
20 // 检验第18为是否与校验码相等 
21 return arrValid[idx] == cid.substr(17, 1).toUpperCase(); 
22 } else { 
23 return false; 
24 } 
25 } 

11.验证15位数身份证号码中的生日是否是有效生日

 1 function isValidityBrithBy15IdCard(idCard15) { 
 2  var year = idCard15.substring(6, 8); 
 3  var month = idCard15.substring(8, 10); 
 4  var day = idCard15.substring(10, 12); 
 5  var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day)); 
 6  // 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法 
 7  if (temp_date.getYear() != parseFloat(year) 
 8    || temp_date.getMonth() != parseFloat(month) - 1 
 9    || temp_date.getDate() != parseFloat(day)) { 
10   return false; 
11  } else { 
12   return true; 
13  } 
14 }

12.验证18位数身份证号码中的生日是否是有效生日

 1 function isValidityBrithBy18IdCard(idCard18) { 
 2  var year = idCard18.substring(6, 10); 
 3  var month = idCard18.substring(10, 12); 
 4  var day = idCard18.substring(12, 14); 
 5  var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day)); 
 6  // 这里用getFullYear()获取年份,避免千年虫问题 
 7  if (temp_date.getFullYear() != parseFloat(year) 
 8    || temp_date.getMonth() != parseFloat(month) - 1 
 9    || temp_date.getDate() != parseFloat(day)) { 
10   return false; 
11  } else { 
12   return true; 
13  } 
14 }

 

posted @ 2018-01-17 15:41  一粒小米-博客  阅读(481)  评论(0编辑  收藏  举报