常用正则


判断邮箱是否合法

const regExp = /\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/
return regExp.test(email)

判断电话号码是否合法

const regExp = /^(((13[0-9])|(14[0-9])|(17[0-9])|(15[0-3])|(15[4-9])|(18[0-9])|(199))+\d{8})$/
return regExp.test(phone)

验证是否是中文字符串

const regExp = /^[\u4E00-\u9FA5]+$/
return regExp.test(name)

验证身份证号码是否合法

  // 15位和18位身份证号码的正则表达式
const regIdCard = /^(^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$)|(^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3}[Xx])$)$/;
            // 如果通过该验证,说明身份证格式正确,但准确性还需计算
            if (regIdCard.test(idCard)) {
                if (idCard.length === 18) {
                    let idCardWi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10,5, 8, 4, 2]; // 将前17位加权因子保存在数组里
                    let idCardY = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2]; // 这是除以11后,可能产生的11位余数、验证码,也保存成数组
                    let idCardWiSum = 0; // 用来保存前17位各自乖以加权因子后的总和
                    for (let i = 0; i < 17; i++) {
                        idCardWiSum += idCard.substring(i, i + 1) * idCardWi[i];
                    }

                    let idCardMod = idCardWiSum % 11;// 计算出校验码所在数组的位置
                    let idCardLast = idCard.substring(17);// 得到最后一位身份证号码

                    // 如果等于2,则说明校验码是10,身份证号码最后一位应该是X
                    if (idCardMod === 2) {
                        return idCardLast === "X" || idCardLast === "x";
                    } else {
                        // 用计算出的验证码与最后一位身份证号码匹配,如果一致,说明通过,否则是无效的身份证号码
                        return idCardLast === idCardY[idCardMod];
                    }
                }else{
                    return true;
                }
            } else {
                return false;
            }

文章作者: 小游
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 小游 !
  目录