• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    12个常用的js正则表达式

    在这篇文章里,我已经编写了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开发中常用的表单验证的正则表达式,希望大家喜欢。

    您可能感兴趣的文章:
    • 比较正宗的验证邮箱的正则表达式js代码详解
    • 实用的JS正则表达式(手机号码/IP正则/邮编正则/电话等)
    • js正则表达式的使用详解
    • JS正则表达式大全(整理详细且实用)
    • JS正则表达式验证数字代码
    • js正则表达式中test,exec,match方法的区别说明
    • js正则表达式匹配数字字母下划线等
    • js正则表达式基本语法(精粹)
    • JavaScript正则表达式验证身份证号码是否合法(两种方法)
    • JavaScript正则表达式解析URL的技巧
    • javascript正则表达式总结
    上一篇:共享日常收集JS正则表达式(JavaScript regular expression)
    下一篇:JavaScript中的正则表达式使用及验证qq号码的正则
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    12个常用的js正则表达式 12个,常用的,常,用的,正则,