开发常用正则验证表达式

 校验秘密相关的正则表达式

密码的正则表达式必须包含至少八个字符,至少一个数字以及大小写字母和特殊字符 - 掘金

// 校验数字的表达式

// 数字:
^[0-9]*$

// n位的数字:
^\d{n}$
// 至少n位的数字:
^\d{n,}$

// m-n位的数字:
^\d{m,n}$

// 零和非零开头的数字:
^(0|[1-9][0-9]*)$

// 非零开头的最多带两位小数的数字:
^([1-9][0-9]*)+(\.[0-9]{1,2})?$

// 带1-2位小数的正数或负数:
^(\-)?\d+(\.\d{1,2})$

// 正数、负数、和小数:
^(\-|\+)?\d+(\.\d+)?$

// 有两位小数的正实数:
^[0-9]+(\.[0-9]{2})?$

// 有1~3位小数的正实数:
^[0-9]+(\.[0-9]{1,3})?$

// 非零的正整数:
^[1-9]\d*$ 或 ^([1-9][0-9]*){1,3}$ 或 ^\+?[1-9][0-9]*$

// 非零的负整数:
^\-[1-9][]0-9"*$ 或 ^-[1-9]\d*$

// 非负整数:
^\d+$ 或 ^[1-9]\d*|0$

// 非正整数:
^-[1-9]\d*|0$ 或 ^((-\d+)|(0+))$

// 浮点数:
^(-?\d+)(\.\d+)?$ 或 ^-?([1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0)$

// 非负浮点数:
^\d+(\.\d+)?$ 或 ^[1-9]\d*\.\d*|0\.\d*[1-9]\d*|0?\.0+|0$

// 非正浮点数:
^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 或 ^(-([1-9]\d*\.\d*|0\.\d*[1-9]\d*))|0?\.0+|0$

// 正浮点数:
^[1-9]\d*\.\d*|0\.\d*[1-9]\d*$ 或 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$

// 负浮点数:
^-([1-9]\d*\.\d*|0\.\d*[1-9]\d*)$
// 或
 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$

// 任何数字:
(-?\d*)(\.\d+)?
// 校验字符的表达式

// 汉字:
^[\u4e00-\u9fa5]{0,}$

// 英文和数字:
^[A-Za-z0-9]+$ 或 ^[A-Za-z0-9]{4,40}$

// 长度为3的字符:
^.{3}$ 

// 长度为3-20的所有字符:
^.{3,20}$

// 由26个英文字母组成的字符串:
^[A-Za-z]+$

// 由26个大写英文字母组成的字符串:
^[A-Z]+$

// 由26个小写英文字母组成的字符串:
^[a-z]+$

// 由数字和26个英文字母组成的字符串:
^[A-Za-z0-9]+$

// 由数字、26个英文字母或者下划线组成的字符串:
^\w+$ 或 ^\w{3,20}$

// 中文、英文、数字包括下划线:
^[\u4E00-\u9FA5A-Za-z0-9_]+$

// 中文、英文、数字但不包括下划线等符号:
^[\u4E00-\u9FA5A-Za-z0-9]+$ 或 ^[\u4E00-\u9FA5A-Za-z0-9]{2,20}$

// 以字母开头,长度在6-18之间,只能包含字符、数字和下划线:
^[a-zA-Z]\w{5,17}$

// 可以输入含有^%&',;=?$\"等字符:
[^%&',;=?$\x22]+

// 禁止输入含有~的字符:
[^~\x22]+

// 是否含有 ^%&',;=?$\" 等字符:
[^%&',;=?$\x22]+ 
// 特殊需求表达式

// 域名:
[a-zA-Z0-9][-a-zA-Z0-9]{0,62}(\.[a-zA-Z0-9][-a-zA-Z0-9]{0,62})+\.?

// 帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):
^[a-zA-Z][a-zA-Z0-9_]{4,15}$

// 密码(以字母开头,长度在6~18之间,只能包含字母、数字和下划线):
^[a-zA-Z]\w{5,17}$

// 强密码(必须包含大小写字母和数字的组合,不能使用特殊字符,长度在 8-10 之间):
^(?=.*\d)(?=.*[a-z])(?=.*[A-Z])[a-zA-Z0-9]{8,10}$

// 强密码(必须包含大小写字母和数字的组合,可以使用特殊字符,长度在8-10之间):
^(?=.*\d)(?=.*[a-z])(?=.*[A-Z]).{8,10}$

// 日期格式:^\d{4}-\d{1,2}-\d{1,2}

// 一年的12个月(01~09和1~12):^(0?[1-9]|1[0-2])$

// 一个月的31天(01~09和1~31):^((0?[1-9])|((1|2)[0-9])|30|31)$

// 钱的输入格式:
// 有四种钱的表示形式我们可以接受:"10000.00" 和 "10,000.00", 和没有 "分" 的 "10000" 和 "10,000":^[1-9][0-9]*$
// 这表示任意一个不以0开头的数字,但是,这也意味着一个字符"0"不通过,所以我们采用下面的形式:^(0|[1-9][0-9]*)$
// 一个0或者一个不以0开头的数字.我们还可以允许开头有一个负号:^(0|-?[1-9][0-9]*)$
// 这表示一个0或者一个可能为负的开头不为0的数字.让用户以0开头好了.把负号的也去掉,因为钱总不能是负的吧。下面我们要加的是说明可能的小数部分:^[0-9]+(.[0-9]+)?$
// 必须说明的是,小数点后面至少应该有1位数,所以"10."是不通过的,但是 "10" 和 "10.2" 是通过的:^[0-9]+(.[0-9]{2})?$
// 这样我们规定小数点后面必须有两位,如果你认为太苛刻了,可以这样:^[0-9]+(.[0-9]{1,2})?$
// 这样就允许用户只写一位小数.下面我们该考虑数字中的逗号了,我们可以这样:^[0-9]{1,3}(,[0-9]{3})*(.[0-9]{1,2})?$
// 1到3个数字,后面跟着任意个 逗号+3个数字,逗号成为可选,而不是必须:^([0-9]+|[0-9]{1,3}(,[0-9]{3})*)(.[0-9]{1,2})?$
// 备注:这就是最终结果了,别忘了"+"可以用"*"替代如果你觉得空字符串也可以接受的话(奇怪,为什么?)最后,别忘了在用函数时去掉去掉那个反斜杠,一般的错误都在这里


// xml文件:^([a-zA-Z]+-?)+[a-zA-Z0-9]+\\.[x|X][m|M][l|L]$

// 中文字符的正则表达式:[\u4e00-\u9fa5]

// 姓名:/^[\u4e00-\u9fa5]{2,4}$/

// 双字节字符(包括汉字在内,可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1))
[^\x00-\xff] 

// 空白行的正则表达式(可以用来删除空白行)
\n\s*\r 

// HTML标记的正则表达式 
<(\S*?)[^>]*>.*?|<.*? />

// ( 首尾空白字符的正则表达式:^\s*|\s*$或(^\s*)|(\s*$) 
// (可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式)

// 腾讯QQ号:[1-9][0-9]{4,} (腾讯QQ号从10000开始)

// 中国邮政编码:[1-9]\d{5}(?!\d) (中国邮政编码为6位数字)
// input 输入框 金额校验、处理

// 清除“数字”和“.”以外的字符
str.replace(/[^\d.]/g, '')

//只保留第一个. 清除多余的
str.replace(/\.{2,}/g, '.')

// 第一位是小数点 自动在前面加0
str.indexOf('.') === 0 ? '0' + str : str

// 第一位不能是小数点
str.indexOf('.') === 0 ? str.slice(1) : str

//没有小数点首位不能是01、02的数字
if (detail.indexOf('.') < 0 && detail != '') {
   detail = parseFloat(detail)
}

// 小数点后只能有两位数字
if (str.indexOf('.') > 0) { // 只能输入两位小数
    const detailArr = strt.split('.')
    if (detailArr[1] && detailArr[1].length > 2) {
      str = str.substring(0, str.length - 1)
    }
}

// 小数点之前只能输入6位以内的数字,旧值替换新值
if(detail.toString().indexOf('.') > 0) { // detail不是整数
  let detailArr = detail.toString().split('.');
  if (detailArr[0].length > 6 || detailArr[1].length > 2) {
    this.setData({
      [`formData.${key}`]: this.data.oldAmount
    })
    return
  }
}
/**
 * 金额,只允许2位小数
 * 检测是否为两位小数的数字
 */
function amount(value) {
    // 金额,只允许保留两位小数
    return /^[1-9]\d*(,\d{3})*(\.\d{1,2})?$|^0\.\d{1,2}$/.test(value)
}

// 密码校验,密码必须由9-16位,数字、大小写字母三种组成
export const pwdValid = (value) => {
	var str = value.trim();
	var reg = /^(?=.*[0-9])(?=.*[a-z])(?=.*[A-Z])(?=.*[0-9a-zA-Z]).{9,16}$/;
	if (reg.test(str)) {
		return true;
	} else {
		return false;
	}
}
// 支付密码:不能为连续或相同数字
function validatePayPassword(number) {
	// 全一样
	if (/^(\d)\1+$/.test(number)) return false
	var str = number.replace(/\d/g, function($0, pos) {
		return parseInt($0) - pos
	})
	if (/^(\d)\1+$/.test(str)) return false // 顺增

	str = number.replace(/\d/g, function($0, pos) {
		return parseInt($0) + pos
	})
	if (/^(\d)\1+$/.test(str)) return false // 顺减
	return true
}
// 合法url
export function validateURL(textval) {
    // 1: [a-zA-z]+://[^\s]*
    // 2: ^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$
    // 3: 
    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)
}
/*验证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;
};
/* 邮箱(Email地址)*/
export function validateEmail(email) {
    // 1: ^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$
    // 2: /^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/
    // 3: /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/
    // 4: 
    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)
}
// 判断手机号码是否正确
function validateTelephone(telephone) {
	let reg = new RegExp(/^(13[0-9]|14[01456879]|15[0-35-9]|16[2567]|17[0-8]|18[0-9]|19[0-35-9])\d{8}$/);
	if (reg.test(telephone)) {
		return true
	}
	return false
}

// 手机号码
// 正则:/^1[23456789]\d{9}$/
// 校验挂车车牌号
function validateTrailerNo(trailerNo) {
	const reg = /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领]{1}[A-Z]{1}[A-HJ-NP-Z0-9]{4}[挂]{1}$/;
	return reg.test(trailerNo)
}
/* 车牌号*/
/**
 * 新能源车辆车牌号生成规则
 * 纯电动车牌共 8 位
 * 纯电动可用字母为:“D”“A”“B”“C”“E” (目前使用D,号码不足依次使用其他号码,非纯电动车同理)
 * 非纯电动可用字母为:“F”"G""H""J""K"(包括插电式混合动力和燃料电池汽车等)
 * 
 * 小型汽车号牌中代表车辆类型的字母(如“D”或“F”)位于后六位号牌序号的第一位
 * 后六位第二位可以使用字母或数字,后四位必须使用数字
 * 
 * 大型汽车号牌中代表车辆类型的字母(如“D”或“F”)位于后六位号牌序号的最后一位
 * 后六位前五位必须为数字
 */
function carNo(value) {
    // 兼容新能源及旧车牌
    const regzong = /(^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领]{1}[A-HJ-NP-Z]{1}(([0-9]{5}[DF])|([DF]([A-HJ-NP-Z0-9])[0-9]{4}))$)|(^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领]{1}[A-HJ-NP-Z]{1}[A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳]{1}$)/
    // 新能源车牌
    const xreg = /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领]{1}[A-HJ-NP-Z]{1}(([0-9]{5}[DF])|([DF]([A-HJ-NP-Z0-9])[0-9]{4}))$/
    // 旧车牌
    const creg = /^[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领]{1}[A-HJ-NP-Z]{1}[A-HJ-NP-Z0-9]{4}[A-HJ-NP-Z0-9挂学警港澳]{1}$/
    if (value.length === 7) {
        return creg.test(value)
    } if (value.length === 8) {
        return xreg.test(value)
    }
    return false
}
// 校验银行卡号
function validateBankcardNo(bankcardNo) {
	const xreg = /([\d]{4})([\d]{4})([\d]{4})([\d]{4})([\d]{0,})?/;
	return xreg.test(bankcardNo)
}
// 校验身份证号码
function validateIdCard(idCard) {
	idCard = idCard.trim(); //去掉字符串头尾空格                                     
	if (idCard.length == 15) {
		return isValidityBrithBy15IdCard(idCard); //进行15位身份证的验证
	} else if (idCard.length == 18) {
		var a_idCard = idCard.split(""); // 得到身份证数组
		if (isValidityBrithBy18IdCard(idCard) && isTrueValidateCodeBy18IdCard(a_idCard)) { //进行18位身份证的基本验证和第18位的验证
			return true;
		} else {
			return false;
		}
	} else {
		return false;
	}
}


function isTrueValidateCodeBy18IdCard(a_idCard) {
	var Wi = [7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2, 1]; // 加权因子
	var ValideCode = [1, 0, 10, 9, 8, 7, 6, 5, 4, 3, 2];
	var sum = 0; // 声明加权求和变量   
	if (a_idCard[17].toLowerCase() == 'x') {
		a_idCard[17] = 10; // 将最后位为x的验证码替换为10方便后续操作   
	}
	for (var i = 0; i < 17; i++) {
		sum += Wi[i] * a_idCard[i]; // 加权求和   
	}
	var valCodePosition = sum % 11; // 得到验证码所位置   
	if (a_idCard[17] == ValideCode[valCodePosition]) {
		return true;
	} else {
		return false;
	}
}


function isValidityBrithBy18IdCard(idCard18) {
	var year = idCard18.substring(6, 10);
	var month = idCard18.substring(10, 12);
	var day = idCard18.substring(12, 14);
	var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
	// 这里用getFullYear()获取年份,避免千年虫问题   
	if (temp_date.getFullYear() != parseFloat(year) ||
		temp_date.getMonth() != parseFloat(month) - 1 ||
		temp_date.getDate() != parseFloat(day)) {
		return false;
	} else {
		return true;
	}
}

function isValidityBrithBy15IdCard(idCard15) {
	var year = idCard15.substring(6, 8);
	var month = idCard15.substring(8, 10);
	var day = idCard15.substring(10, 12);
	var temp_date = new Date(year, parseFloat(month) - 1, parseFloat(day));
	// 对于老身份证中的你年龄则不需考虑千年虫问题而使用getYear()方法   
	if (temp_date.getYear() != parseFloat(year) ||
		temp_date.getMonth() != parseFloat(month) - 1 ||
		temp_date.getDate() != parseFloat(day)) {
		return false;
	} else {
		return true;
	}
}

if(!/^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}([0-9]|X)$/.test(this.uploadForm.IdCardNumber)) {
    this.$vux.toast.text('身份证号格式不正确', "default");
    return
}
/* IP地址 (IPv4地址)*/
export function validateIpAdr(ipAdr) {
    // 1: /^(\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])$/

    const reg = /^(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])\.(\d|[1-9]\d|1\d{2}|2[0-4]\d|25[0-5])$/
    return reg.test(ipAdr)
}
/* 端口号*/
export function validatePort(port) {
    // /^([1-9]\d{0,3}|[0-9]{1,4}|0)$/
  const reg = /^([0-9]|[1-9]\d{1,3}|[1-5]\d{4}|6[0-4]\d{4}|65[0-4]\d{2}|655[0-2]\d|6553[0-5])$/
  return reg.test(port)
}
// 检查IE的版本
var reg = /^.*MSIE [5-8](?:\\.[0-9]+)?(?!.*Trident\\\/[5-9]\\.0).*$/;
function isQQ(aQQ) { // QQ号
  var bValidate = RegExp(/^[1-9][0-9]{4,9}$/).test(aQQ);
  if (bValidate) {
    return true;
  }
  else
    return false;
}

function isWeiXin(weixin) { // 微信号
  var bValidate = RegExp(/^[a-zA-Z\d_]{5,}$/).test(weixin);
  if (bValidate) {
    return true;
  }
  else
    return false;
}

function containsChinese(value) { // 是否包含中文
  if (/.*[\u4e00-\u9fa5]+.*$/.test(value)) {
    return false;
  }
  return true;
}
// 提取Color Hex Codes
// 有时需要抽取网页中的颜色代码,可以使用下面的表达式。
var reg = /^#([A-Fa-f0-9]{6}|[A-Fa-f0-9]{3})$/;
// 查找CSS属性
// 通过下面的表达式,可以搜索到相匹配的CSS属性。
var reg = /^\\s*[a-zA-Z\\-]+\\s*[:]{1}\\s[a-zA-Z0-9\\s.#]+[;]{1}/;
// 提取网页图片
// 假若你想提取网页中所有图片信息,可以利用下面的表达式。
var reg = /\\< *[img][^\\>]*[src] *= *[\\"\']{0,1}([^\\"\'\ >]*)/;

// 匹配html标签
// p,img,自定义
let reg = /<p(?:(?!<\/p>).|\n)*?<\/p>/gm;
let reg = /<img(?:(?!\/>).|\n)*?\/>/gm;
let reg = /<自定义(?:(?!<\/自定义>).|\n)*?<\/自定义>/gm;
/** 是否图片格式
 * @param {Object} value
 */
function image(value) {
    const IMAGE_REGEXP = /\.(jpeg|jpg|gif|png|svg|webp|jfif|bmp|dpg)/i
    return IMAGE_REGEXP.test(value)
}
/**
 * 是否视频格式
 * @param {Object} value
 */
function video(value) {
    const VIDEO_REGEXP = /\.(mp4|mpg|mpeg|dat|asf|avi|rm|rmvb|mov|wmv|flv|mkv)/i
    return VIDEO_REGEXP.test(value)
}

前端常用的60余种工具方法

  • 3
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值