网络编程 
首页 > 网络编程 > 浏览文章

12个常用的js正则表达式

(编辑:jimmy 日期: 2024/11/28 浏览:3 次 )

在这篇文章里,我已经编写了12个超有用的正则表达式,这可是WEB开发人员的最爱哦。

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

//第一种在input输入框限制 
 <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*(">元 
//第二种对于表单动态增加的方式,只能在js方法中验证。 
 var amount=$("#amount").val(); 
 if (amount.search(/^\d*("金额格式不对,最多有两位小数"); 
   return false; 
} 

2.验证邮箱格式

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

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

function validatePwd(str) { 
if (/^.*"htmlcode">
/** 
 * 验证电话号码 
 * @param phoneValue 要验证的电话号码 
 * @returns 匹配返回true 不匹配返回false 
 */ 
function validatePhone(phoneValue) { 
 phoneValue = valueTrim(phoneValue); 
 var reg = /^[1][0-9]{10}$/; 
 return reg.test(phoneValue); 
} 

5.判断是否是汉字

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

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

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

7.判断是否为数字

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

8.整数的正则表达式

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

9.是否为字母和数字

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

10.检验18位身份证号码 

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

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

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

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

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

这就是小编整理的web开发中常用的表单验证的正则表达式,希望大家喜欢。

上一篇:JavaScript中的正则表达式使用及验证qq号码的正则
下一篇:共享日常收集JS正则表达式(JavaScript regular expression)
高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap