正则校验的多种方式

1.IP地址:端口

let ipReg=/^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\:([0-9]|[1-9]\d{1,3}|[1-5]\d{4}|6[0-5]{2}[0-3][0-5])$/

2.IP地址

let ipReg =  /^(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|[1-9])(\.(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|\d)){3}$/

3.网址,以http或https协议开头

let httpReg = /http(s)?:\/\/([\w-]+\.)+[\w-]+(\/[\w- .\/?%&=]*)?/

4.统一社会信用代码格式

let httpReg = /^[^_IOZSVa-z\W]{2}\d{6}[^_IOZSVa-z\W]{10}$/g

5.邮箱

let emailReg=/[\w!#$%&'*+/=?^_`{|}~-]+(?:\.[\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?/

6.手机号

let phoneReg= /^[1][3,4,5,6,7,8,9][0-9]{9}$/

7.涉及多选的

  {

            type: 'array',

            required: true,

            message: '请至少选择一个数据要素服务商',

            trigger: 'change',

          },

校验的几种写法

1.直接在绑定的form表单中rules中定义

rules:{
  contact: [
          { required: true, message: '请输入联系人', trigger: 'blur' },
          { max: 64, message: '长度在 64 个字符内', trigger: 'blur' },
        ],
}

2.利用pattern实现正则的验证

email: [
          { required: true, message: '请输入邮箱', trigger: 'blur' },
          {
            required: true,
            pattern:
              /[\w!#$%&'*+/=?^_`{|}~-]+(?:\.[\w!#$%&'*+/=?^_`{|}~-]+)*@(?:[\w](?:[\w-]*[\w])?\.)+[\w](?:[\w-]*[\w])?/,
            message: '请输入正确的邮箱格式',
            trigger: 'blur',
          },
        ],

3.涉及数字范围的验证

涉及的input中的数据类型要进行转换
input输入的内容都是字符串的形式
v-model.number=""  //转换为数字

 port: [
          {
            required: blur,
            type: 'number',
            min: 1,
            max: 65535,
            message: '请输入范围之内的端口',
          },
        ],

4.利用validator方法实现校验

  const validateCode = (rule, value, callback) => {
      let httpReg = /^[^_IOZSVa-z\W]{2}\d{6}[^_IOZSVa-z\W]{10}$/g
      if (value !== '') {
        if (!httpReg.test(value)) {
          callback(new Error('统一社会信用代码格式不正确'))
        } else {
          callback()
        }
      } else {
        callback(new Error('请输入统一社会信用代码'))
      }
    }


   rules:{
      uscc: [
          { required: true, validator: validateCode, trigger: 'blur' },
        ],
   }

校验DNS服务器地址

100.125.0.28,100.125.0.2 ,输入形式:多个地址以,隔开

 const checkIp = (rule, value, callback) => {

      // console.log(value, '输入的ip')

      let checkIp4 =

        /^((2(5[0-5]|[0-4]\d))|[0-1]?\d{1,2})(\.((2(5[0-5]|[0-4]\d))|[0-1]?\d{1,2})){3}$/

      let valdata = value.split(/[,;\s]+/g)

      // console.log(valdata)

      let isCorrect = true

      if (valdata.length) {

        for (let i = 0; i < valdata.length; i++) {

          if (checkIp4.test(valdata[i]) == false) {

            isCorrect = false

          }

        }

      }

      if (value == null || value == '' || value == 'undefined') {

        return callback('请输入ip')

      } else if (!isCorrect) {

        callback(new Error('请输入正确的ip地址'))

      } else {

        callback()

      }

    }

/**
 * Created by PanJiaChen on 16/11/18.
 */

/**
 * @param {string} path
 * @returns {Boolean}
 */
export function isExternal(path) {
  return /^(https?:|mailto:|tel:)/.test(path)
}


/**
 * @param {string} url
 * @returns {Boolean}
 */
export function validURL(url) {
  const reg = /^(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 reg.test(url)
}

/**
 * @param {string} str
 * @returns {Boolean}
 */
export function validLowerCase(str) {
  const reg = /^[a-z]+$/
  return reg.test(str)
}

/**
 * @param {string} str
 * @returns {Boolean}
 */
export function validUpperCase(str) {
  const reg = /^[A-Z]+$/
  return reg.test(str)
}

/**
 * @param {string} str
 * @returns {Boolean}
 */
export function validAlphabets(str) {
  const reg = /^[A-Za-z]+$/
  return reg.test(str)
}

/**
 * @param {string} email
 * @returns {Boolean}
 */
export function validEmail(email) {
  const reg = /^(([^<>()\[\]\\.,;:\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 reg.test(email)
}

/**
 * @param {string} str
 * @returns {Boolean}
 */
export function isString(str) {
  if (typeof str === 'string' || str instanceof String) {
    return true
  }
  return false
}

/**
 * @param {Array} arg
 * @returns {Boolean}
 */
export function isArray(arg) {
  if (typeof Array.isArray === 'undefined') {
    return Object.prototype.toString.call(arg) === '[object Array]'
  }
  return Array.isArray(arg)
}

/**
 * @param {Array} arg
 * @returns {Boolean}
 */
export function ipaddress(IP) {
  let partten = /^(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|[1-9])(\.(1\d{2}|2[0-4]\d|25[0-5]|[1-9]\d|\d)){3}$/
  if (IP && !partten.test(IP)) {
    return false
  }
  return true
}


版权声明:本文为lf811原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。