12个常用的js正则表达式
程序员文章站
2022-04-16 12:21:52
在这篇文章里,我已经编写了12个超有用的正则表达式,这可是web开发人员的最爱哦。
1.在input框中只能输入金额,其实就是只能输入最多有两位小数的数字...
在这篇文章里,我已经编写了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*(?:\.\d{0,2})?$/)==-1) this.value=(this.value2)?this.value2:'';else this.value2=this.value;">元 //第二种对于表单动态增加的方式,只能在js方法中验证。 var amount=$("#amount").val(); if (amount.search(/^\d*(?:\.\d{0,2})?$/)==-1) { alert("金额格式不对,最多有两位小数"); 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 (/^.*?[\d]+.*$/.test(str) && /^.*?[a-za-z]/.test(str) && /^.*?[~/`!@#$%^&*()_+|{}?;:><\-\]\\[\/].*$/.test(str) && /^.{8,20}$/.test(str)) { return true; } return false; }
4.验证电话号码
/** * 验证电话号码 * @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开发中常用的表单验证的正则表达式,希望大家喜欢。
上一篇: 超常用的PHP正则表达式收集整理
下一篇: 半小时精通正则表达式-精华版