JS正则表达式

js代码
<script type="text/javascript">
function SubmitCk() {
	var reg = /^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/;
	if (!reg.test($("#txtEmail").val())) {
		alert("请输入正确邮箱地址")
		return false;
	}
}

// 第一步:先把非数字的都替换掉,除了数字和.
// 第二步:必须保证第一个为数字而不是.
// 第三步:第一位0开头,0后面为数字,则过滤掉,取后面的数字
// 第四步:最终匹配得到结果 以数字开头,只有一个小数点,而且小数点后面只能有0到2位小数
('' + value).replace(/[^\d.]/g, '').replace(/^\./g, '').replace(/^0+(\d)/, '$1').match(/^\d*(\.?\d{0,2})/g)[0] || ''

checkDigitCapacity (obj, value) {
   const { flag, key, ratio = 2 } = obj
   let checkPlan = '' + flag[key]
   checkPlan = checkPlan
     .replace(/[^\d.]/g, '') // 清除“数字”和“.”以外的字符
     .replace(/\.{2,}/g, '.') // 只保留第一个. 清除多余的
     .replace(/^\./g, '') // 保证第一个为数字而不是.
     .replace('.', '$#$')
     .replace(/\./g, '')
     .replace('$#$', '.')
   if (checkPlan.indexOf('.') < 0 && checkPlan !== '') {
     // 以上已经过滤,此处控制的是如果没有小数点,首位不能为类似于 01、02的金额
     checkPlan = parseFloat(checkPlan) + ''
   } else if (checkPlan.indexOf('.') >= 0) {
     checkPlan = checkPlan
       .replace(/^()*(\d+)\.(\d\d\d).*$/, '$1$2.$3') // 只能输入两个小数
   }
   this.$set(flag, key, checkPlan)
 }

</script>
# 验证数字的正则表达式集 
验证数字:^[0-9]*$
验证n位的数字:^\d{n}$
验证至少n位数字:^\d{n,}$
验证m-n位的数字:^\d{m,n}$
验证零和非零开头的数字:^(0|[1-9][0-9]*)$
验证有两位小数的正实数:^[0-9]+(.[0-9]{2})?$
验证有1-3位小数的正实数:^[0-9]+(.[0-9]{1,3})?$
验证非零的正整数:^\+?[1-9][0-9]*$
验证非零的负整数:^\-[1-9][0-9]*$
验证非负整数(正整数 + 0^\d+$
验证非正整数(负整数 + 0^((-\d+)|(0+))$
验证长度为3的字符:^.{3}$
验证由26个英文字母组成的字符串:^[A-Za-z]+$
验证由26个大写英文字母组成的字符串:^[A-Z]+$
验证由26个小写英文字母组成的字符串:^[a-z]+$
验证由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$
验证由数字、26个英文字母或者下划线组成的字符串:^\w+$
验证用户密码:^[a-zA-Z]\w{5,17}$ 正确格式为:以字母开头,长度在6-18之间,只能包含字符、数字和下划线。
验证是否含有 ^%&',;=?$\" 等字符:[^%&',;=?$\x22]+
验证汉字:^[\u4e00-\u9fa5],{0,}$
验证Email地址:/^([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+@([a-zA-Z0-9]+[_|\_|\.]?)*[a-zA-Z0-9]+\.[a-zA-Z]{2,3}$/
验证InternetURL:^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$ ;^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$
验证电话号码:^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$:--正确格式为:XXXX-XXXXXXXXXXX-XXXXXXXXXXX-XXXXXXXXXX-XXXXXXXXXXXXXXXXXXXXXXX。
验证身份证号(15位或18位数字):^\d{15}|\d{}18$
验证一年的12个月:^(0?[1-9]|1[0-2])$ 正确格式为:“01-09”和“1”“12”
验证一个月的31天:^((0?[1-9])|((1|2)[0-9])|30|31)$ 正确格式为:0109131。
整数:^-?\d+$
非负浮点数(正浮点数 + 0):^\d+(\.\d+)?$
正浮点数 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$
非正浮点数(负浮点数 + 0^((-\d+(\.\d+)?)|(0+(\.0+)?))$
负浮点数 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$
浮点数 ^(-?\d+)(\.\d+)?$



解决JS中小数计算精度问题
function floatAdd(arg1,arg2){    
		    var r1,r2,m;    
		    try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}    
		    try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}    
		    m=Math.pow(10,Math.max(r1,r2));    
		    return (arg1*m+arg2*m)/m;    
		}    
		      
		//减    
		function floatSub(arg1,arg2){    
		    var r1,r2,m,n;    
		    try{r1=arg1.toString().split(".")[1].length}catch(e){r1=0}    
		    try{r2=arg2.toString().split(".")[1].length}catch(e){r2=0}    
		    m=Math.pow(10,Math.max(r1,r2));    
		    //动态控制精度长度    
		    n=(r1>=r2)?r1:r2;    
		    return ((arg1*m-arg2*m)/m).toFixed(n);    
		}    
		       
		//乘    
		function floatMul(arg1,arg2)   {     
		    var m=0,s1=arg1.toString(),s2=arg2.toString();     
		    try{m+=s1.split(".")[1].length}catch(e){}     
		    try{m+=s2.split(".")[1].length}catch(e){}     
		    return Number(s1.replace(".","")) * Number(s2.replace(".","")) /Math.pow(10,m);     
		}     
		      
		      
		//除   
		function floatDiv(arg1,arg2){     
		    var t1=0,t2=0,r1,r2;     
		    try{t1=arg1.toString().split(".")[1].length}catch(e){}     
		    try{t2=arg2.toString().split(".")[1].length}catch(e){}     
		        
		    r1=Number(arg1.toString().replace(".",""));  
		   
		    r2=Number(arg2.toString().replace(".",""));     
		    return (r1/r2)*Math.pow(10,t2-t1);     
		}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值