js 常见字符串检验规则封装总结

1、检验手机号

	// 检验手机号
    function checkPhones (val) {
      let number = /^[1][3,4,5,6,9,7,8][0-9]{9}$/
      if (!number.test(val)) {
        return true
      } else {
        return false
      }
    },

2、检验是否为汉字

    // 检验文字
    function checkNames (val) {
      let NameReg = /^[\u4E00-\u9FA5]{2,20}$/
      if (!NameReg.test(val)) {
        return true
      } else {
        return false
      }
    }

3、检验邮箱

    // 检验邮箱
    function checkEmails (val) {
      if (val.length > 40) {
        return true
      }
      let EmailReg = /^[a-zA-Z0-9_-]+@([a-zA-Z0-9]+\.)+(com|cn|net|org)$/i
      if (val && !EmailReg.test(val)) {
        return true
      } else {
        return false
      }
    }

4、检验身份证号

    // 检验身份证号
    function checkCodes (id) {
      // 1 "验证通过!", 0 //校验不通过 // id为身份证号码
      var format = /^(([1][1-5])|([2][1-3])|([3][1-7])|([4][1-6])|([5][0-4])|([6][1-5])|([7][1])|([8][1-2]))\d{4}(([1][9]\d{2})|([2]\d{3}))(([0][1-9])|([1][0-2]))(([0][1-9])|([1-2][0-9])|([3][0-1]))\d{3}[0-9xX]$/
      // 号码规则校验
      if (!format.test(id)) {
        return true
      }
      // 区位码校验
      // 出生年月日校验  前正则限制起始年份为1900;
      var year = id.substr(6, 4) // 身份证年
      var month = id.substr(10, 2) // 身份证月
      var date = id.substr(12, 2) // 身份证日
      var time = Date.parse(month + '-' + date + '-' + year) // 身份证日期时间戳date
      var nowTime = Date.parse(new Date()) // 当前时间戳
      var dates = new Date(year, month, 0).getDate() // 身份证当月天数
      if (time > nowTime || date > dates) {
        return true
      }
      // 校验码判断
      var c = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2] // 系数
      var b = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'] // 校验码对照表
      var idArray = id.split('')
      var sum = 0
      for (var k = 0; k < 17; k++) {
        sum += parseInt(idArray[k]) * parseInt(c[k])
      }
      if (idArray[17].toUpperCase() !== b[sum % 11].toUpperCase()) {
        return true
      }
      return false
    }

5、检验信用代码

    // 检验信用代码
    function checkCredits (val) {
      let region = /(^[A-Z0-9]{18}$)/
      if (!region.test(val)) {
        return true
      } else {
        return false
      }
    }

6、检验银行账号

    // 检验银行账号
    function checkBankCode (val) {
      let BankCode = /^\d{12,32}$/
      if (!BankCode.test(val)) {
        return true
      } else {
        return false
      }
    }

7、检验密码

    // 检验密码(6~20位非空字符)
    function checkPassword (val) {
      let pwdCode = /\S{6,20}/
      if (!pwdCode.test(val)) {
        return true
      } else {
        return false
      }
    }

8、检验字符串字节长度

    // 检验字符串字节长度
    checkStrByte (str) {
      return new Blob([str]).size
    }

9、其它证件类型检验正则

    护照号: /(^[a-zA-Z0-9]{20}$)/
    军官证号: /(^[0-9]{7}$)/
    士兵证号: /(^[0-9]{7}$)/
    回乡证号: /(^[a-zA-Z][0-9]{10}$)/
    警官证号: /(^[0-9]{1,7}$)/
    台胞证号: /(^[a-zA-Z0-9]\d{0,7}$)/

文章作者: qiangqiang
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 qiangqiang !
评论
 上一篇
vue支付密码插件实现(可解决浏览器记住密码行为) vue支付密码插件实现(可解决浏览器记住密码行为)
浏览器自动填充和记住密码行为是前端遇到最为头疼的问题之一,浏览器只要检查到password input框,就会匹配离他最近的text input框,autocomplete属性虽能解决自动填充的问题,但是也是支持有限,不能解决浏览器记住密
2019-11-11
下一篇 
js检查字符串字节长度 js检查字符串字节长度
Blob对象有size属性,返回字节长度,看官方说明 要获得字符串的字节长度,看下Blob函数首先要说明的是 js 中的DOMString通过Blob函数会被编译成UTF-8 来看下实现例子:
2019-10-25
  目录