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}$)/
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在JavaScript中,空字符串是一种特殊的字符串,它不包含任何字符。当我们与空字符串进行比较时,会遵循以下规则: 1. 空字符串与非空字符串的比较:空字符串与非空字符串进行比较时,JavaScript会将非空字符串转换为布尔类型。如果非空字符串转换为布尔值为true,则空字符串被认为比非空字符串小;如果非空字符串转换为布尔值为false,则空字符串被认为比非空字符串大。 例如: "" < "abc" // true "" < "" // false "" < "true" // true "" < "false" // true 2. 空字符串与数字的比较:空字符串与数字进行比较时,JavaScript会将空字符串转换为数字0。因此,空字符串被认为等于0。 例如: "" == 0 // true "" > 0 // false 3. 空字符串与其他类型的比较:空字符串与其他类型(如布尔类型、数组、对象等)进行比较时,JavaScript会将空字符串转换为布尔类型或其他类型,然后再进行比较。 例如: "" == false // true "" > false // false 需要注意的是,JavaScript中的字符串比较是基于Unicode编码顺序进行的,而不是基于字符串的实际长度或字母表顺序。因此,在比较字符串时,可能会出现意想不到的结果。要避免这种情况,我们可以使用严格相等运算符(===)来进行比较,它不会进行类型转换。 总之,JavaScript中的空字符串比较规则取决于与空字符串进行比较的数据类型和操作符。进行比较时,我们需要了解自动类型转换的规则,以得到正确的比较结果。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值