首页 > 编程 > Regex > 正文

12个常用的js正则表达式

2020-03-16 21:01:48
字体:
来源:转载
供稿:网友

这篇文章为大家分享了12个常用的js表单验证正则表达式,对于开发人员来说,正则表达式是一个非常有用的功能,它提供了 查找,匹配,替换 句子,单词,或者其他格式的字符串,需要的朋友可以参考下

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

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;  

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. }  

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. }  

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


注:相关教程知识阅读请移步到正则表达式频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表