【js】js校验

news/2024/7/19 15:21:55 标签: js

1.合法的uri

/* 合法uri */
export function validateURL(textval) {
  const urlregex = /^(https?|ftp):\/\/([a-zA-Z0-9.-]+(:[a-zA-Z0-9.&%$-]+)*@)*((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9][0-9]?)(\.(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[1-9]?[0-9])){3}|([a-zA-Z0-9-]+\.)*[a-zA-Z0-9-]+\.(com|edu|gov|int|mil|net|org|biz|arpa|info|name|pro|aero|coop|museum|[a-zA-Z]{2}))(:[0-9]+)*(\/($|[a-zA-Z0-9.,?'\\+&%$#=~_-]+))*$/
  return urlregex.test(textval)
}

2.邮箱

/**
 * 邮箱
 * @param {*} s
 */
export function isEmail(s) {
  // return /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((.[a-zA-Z0-9_-]{2,3}){1,2})$/.test(s)
  return /^(([^()[\]\\.,;:\s@\\']+(\.[^()[\]\\.,;:\s@\\']+)*)|(\\'.+\\'))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/.test(s)
}

/**
 * validate email
 * @param email
 * @returns {boolean}
 */
export function validateEmail(email) {
  const re = /^(([^<>()\\[\]\\.,;:\s@']+(\.[^<>()\\[\]\\.,;:\s@']+)*)|('.+'))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/
  return re.test(email)
}

3.手机号

/**
 * 手机号码
 * @param {*} s
 */
export function isMobile(s) {
  // return /^1[0-9]{10}$/.test(s)
  return /^((\+86)|(86))?[1][3456789][0-9]{9}$/.test(s)
}

/**
 * 判断手机号码是否正确
 */
export function isvalidatemobile(phone) {
  const list = []
  let result = true
  let msg = ''
  var isPhone = /^0\d{2,3}-?\d{7,8}$/
  // 增加134 减少|1349[0-9]{7},增加181,增加145,增加17[678]
  if (!validatenull(phone)) {
    if (phone.length === 11) {
      if (isPhone.test(phone)) {
        msg = '手机号码格式不正确'
      } else {
        result = false
      }
    } else {
      msg = '手机号码长度不为11位'
    }
  } else {
    msg = '手机号码不能为空'
  }
  list.push(result)
  list.push(msg)
  return list
}

4.电话号码

/**
 * 电话号码
 * @param {*} s
 */
export function isPhone(s) {
  return /^([0-9]{3,4}-)?[0-9]{7,8}$/.test(s)
}

5.url地址

/**
 * URL地址
 * @param {*} s
 */
export function isURL(s) {
  return /^http[s]?:\/\/.*/.test(s)
}

6.小写字母

/* 小写字母 */
export function validateLowerCase(str) {
  const reg = /^[a-z]+$/
  return reg.test(str)
}

7.大写字母

/* 大写字母 */
export function validateUpperCase(str) {
  const reg = /^[A-Z]+$/
  return reg.test(str)
}

8.大小写字母

/* 大小写字母 */
export function validatAlphabets(str) {
  const reg = /^[A-Za-z]+$/
  return reg.test(str)
}

9.验证pad还是pc

/* 验证pad还是pc */
export const vaildatePc = function() {
  const userAgentInfo = navigator.userAgent
  const Agents = ['Android', 'iPhone',
    'SymbianOS', 'Windows Phone',
    'iPad', 'iPod'
  ]
  let flag = true
  for (var v = 0; v < Agents.length; v++) {
    if (userAgentInfo.indexOf(Agents[v]) > 0) {
      flag = false
      break
    }
  }
  return flag
}

10.判断身份证号码


/**
 * 判断身份证号码
 */
export function cardid(code) {
  const list = []
  let result = true
  let msg = ''
  var city = {
    11: '北京',
    12: '天津',
    13: '河北',
    14: '山西',
    15: '内蒙古',
    21: '辽宁',
    22: '吉林',
    23: '黑龙江 ',
    31: '上海',
    32: '江苏',
    33: '浙江',
    34: '安徽',
    35: '福建',
    36: '江西',
    37: '山东',
    41: '河南',
    42: '湖北 ',
    43: '湖南',
    44: '广东',
    45: '广西',
    46: '海南',
    50: '重庆',
    51: '四川',
    52: '贵州',
    53: '云南',
    54: '西藏 ',
    61: '陕西',
    62: '甘肃',
    63: '青海',
    64: '宁夏',
    65: '新疆',
    71: '台湾',
    81: '香港',
    82: '澳门',
    91: '国外 '
  }
  if (!validatenull(code)) {
    if (code.length === 18) {
      if (!code || !/(^\d{18}$)|(^\d{17}(\d|X|x)$)/.test(code)) {
        msg = '证件号码格式错误'
      } else if (!city[code.substr(0, 2)]) {
        msg = '地址编码错误'
      } else {
        // 18位身份证需要验证最后一位校验位
        code = code.split('')
        // ∑(ai×Wi)(mod 11)
        // 加权因子
        var factor = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2]
        // 校验位
        var parity = [1, 0, 'X', 9, 8, 7, 6, 5, 4, 3, 2, 'x']
        var sum = 0
        var ai = 0
        var wi = 0
        for (var i = 0; i < 17; i++) {
          ai = code[i]
          wi = factor[i]
          sum += ai * wi
        }
        if (parity[sum % 11] !== code[17]) {
          msg = '证件号码校验位错误'
        } else {
          result = false
        }
      }
    } else {
      msg = '证件号码长度不为18位'
    }
  } else {
    msg = '证件号码不能为空'
  }
  list.push(result)
  list.push(msg)
  return list
}

11.判断姓名是否正确

/**
 * 判断姓名是否正确
 */
export function validatename(name) {
  var regName = /^[\u4e00-\u9fa5]{2,4}$/
  if (!regName.test(name)) return false
  return true
}

12.判断是否为整数

/**
 * 判断是否为整数
 */
export function validatenum(num, type) {
  let regName = /[^\d.]/g
  if (type === 1) {
    if (!regName.test(num)) return false
  } else if (type === 2) {
    regName = /[^\d]/g
    if (!regName.test(num)) return false
  }
  return true
}

13.判断是否为自然数

/**
 * 判断是否为自然数
 */
export function validateNaturalNum(num) {
  const regName = /^[1-9]+[0-9]*$/
  if (!regName.test(num)) {
    return false
  }
  return true
}

14.判断是否为正整数

/**
 * 判断是否为正整数
 */
export function validatePositiveInteger(num){
  var regName = /^[1-9]+\d*$/
  if(!regName.test(num)) {
    return false
  }
  return true
} 

15.判断是否为小数

/**
 * 判断是否为小数
 */
export function validatenumord(num, type) {
  let regName = /[^\d.]/g
  if (type === 1) {
    if (!regName.test(num)) return false
  } else if (type === 2) {
    regName = /[^\d.]/g
    if (!regName.test(num)) return false
  }
  return true
}

16.判断是否为空

/**
 * 判断是否为空
 */
export function validatenull(val) {
  if (typeof val === 'boolean') {
    return false
  }
  if (typeof val === 'number') {
    return false
  }
  if (val instanceof Array) {
    if (val.length === 0) return true
  } else if (val instanceof Object) {
    if (JSON.stringify(val) === '{}') return true
  } else {
    if (val === 'null' || val == null || val === 'undefined' || val === undefined || val === '') {
      return true
    }
    return false
  }
  return false
}

17.校验是否有特殊字符

export function validateChar(text) {
  let regName = new RegExp("^@?([\u4E00-\uFA29]|[\uE7C7-\uE7F3]|[a-zA-Z0-9])+(\\|@?([\u4E00-\uFA29]|[\uE7C7-\uE7F3]|[a-zA-Z0-9])+)*$");
  if(regex.test(text)){
  	 return false;
  }
  return true
}


http://www.niftyadmin.cn/n/903288.html

相关文章

【vue】el-select控件避免修改全局样式用属性popper-append-to-body

1.问题说明 1.默认el-select的popper-append-to-body属性是true,打开的el-select的气泡会追加到body中&#xff0c;导致局部样式无法修改 2.修改popper-append-to-body为true&#xff0c;气泡会追加到el-select控件上去&#xff0c;这样在el-select上加class属性便可以修改局部…

【vue】el-upload上传示例

1.前端代码 <template><div><el-uploadstyle"height: 100%"ref"upload"action"action":limit"limitNum":auto-upload"true":drag"true":accept"accept":show-file-list"false&quo…

【mysql】排序分页查询导致数据混乱问题

1.问题说明 1.根据创建时间排序&#xff0c;当创建时间大量重复时&#xff0c;分页查询会导致某条数据出现在不同分页中 select * from student order by create_time desc limit 10,10; select * from student order by create_time desc limit 20,10;2.问题解决 1.如果有id主…

【vue】avue-crud中filter-change过滤事件问题

1.问题说明 1.准备在filter表头过滤时做后台查询过滤&#xff0c;但无法获取是哪一列 2.avue-crud的filter-change事件中未封装column信息&#xff0c;这样在filter-change方法回调的时候&#xff0c;参数里只有默认的column信息&#xff0c;如果过滤的表头过多&#xff0c;无法…

【jvm】jvm基础学习篇-1

1.什么是JVM 1.Java Virtual Machine:java程序的运行环境&#xff08;java二进制字节码的运行环境&#xff09; 2.JVM的优点 1.一次编写&#xff0c;到处运行 2.自动内存管理&#xff0c;垃圾回收机制 3.数组下标越界检查 4.多态 3.JVM与JRE、JDK的比较 JVM JRE(JVM基础类库) J…

【idea】idea创建maven+spingboot项目

1.创建项目 2.选择Spring Initializr和jdk 3.填写Group和Artifact 4.选择Spring Web 5.完成

【java】springboot整合mybatis-plus报org.apache.ibatis.binding.BindingException: Invalid bound statement错误

1.解决方式 在pom文件中加入 <build><resources><resource><directory>src/main/resources</directory><filtering>true</filtering></resource><resource><directory>src/main/java</directory><incl…

【vue】el-menu菜单切换页面示例

1.示例图片 2.代码结构 3.main.js 主要代码为import router from ‘./router’&#xff0c;并且在new Vue中加入router import Vue from vue import App from ./App import router from ./router import Element from element-ui import element-ui/lib/theme-chalk/index.css …