手机号码、电子邮箱、身份证、银行卡正则验证

本文介绍了使用正则表达式验证手机号、电子邮箱、身份证号码和银行卡号的方法,包括详细的正则表达式和一个用于验证银行卡号是否符合Luhn算法的函数。

手机号码:

var myreg =
/
^1(3[0-9]|4[57]|5[0-35-9]|7[0135678]|8[0-9])\d{8}$
/
;

电子邮箱:

/^[a-z0-9] ([._\\-]*[a-z0-9])*@([a-z0-9] [-a-z0-9]*[a-z0-9] .){1,63}[a-z0-9] $/i

身份证:

var isIDCard1=/^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$/;
var isIDCard2=/^[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)$/;

正数:

var ex = /^(\ )?\d (\.\d )?$/; //正浮点数

银行卡:

function luhmCheck(bankno){
        var lastNum=bankno.substr(bankno.length-1,1);//取出最后一位(与luhm进行比较)

        var first15Num=bankno.substr(0,bankno.length-1);//前15或18位
        var newArr=new Array();
        for(var i=first15Num.length-1;i>-1;i--){    //前15或18位倒序存进数组
            newArr.push(first15Num.substr(i,1));
        }
        var arrJiShu=new Array();  //奇数位*2的积 <9
        var arrJiShu2=new Array(); //奇数位*2的积 >9

        var arrOuShu=new Array();  //偶数位数组
        for(var j=0;j<newArr.length;j  ){
            if((j 1)%2==1){//奇数位
                if(parseInt(newArr[j])*2<9)
                    arrJiShu.push(parseInt(newArr[j])*2);
                else
                    arrJiShu2.push(parseInt(newArr[j])*2);
            }
            else //偶数位
                arrOuShu.push(newArr[j]);
        }

        var jishu_child1=new Array();//奇数位*2 >9 的分割之后的数组个位数
        var jishu_child2=new Array();//奇数位*2 >9 的分割之后的数组十位数
        for(var h=0;h<arrJiShu2.length;h  ){
            jishu_child1.push(parseInt(arrJiShu2[h]));
            jishu_child2.push(parseInt(arrJiShu2[h])/10);
        }

        var sumJiShu=0; //奇数位*2 < 9 的数组之和
        var sumOuShu=0; //偶数位数组之和
        var sumJiShuChild1=0; //奇数位*2 >9 的分割之后的数组个位数之和
        var sumJiShuChild2=0; //奇数位*2 >9 的分割之后的数组十位数之和
        var sumTotal=0;
        for(var m=0;m<arrJiShu.length;m  ){
            sumJiShu=sumJiShu parseInt(arrJiShu[m]);
        }

        for(var n=0;n<arrOuShu.length;n  ){
            sumOuShu=sumOuShu parseInt(arrOuShu[n]);
        }

        for(var p=0;p<jishu_child1.length;p  ){
            sumJiShuChild1=sumJiShuChild1 parseInt(jishu_child1[p]);
            sumJiShuChild2=sumJiShuChild2 parseInt(jishu_child2[p]);
        }
        //计算总和
        sumTotal=parseInt(sumJiShu) parseInt(sumOuShu) parseInt(sumJiShuChild1) parseInt(sumJiShuChild2);

        //计算Luhm值
        var k= parseInt(sumTotal)==0?10:parseInt(sumTotal);
        var luhm= 10-k;

        if(lastNum==luhm){
            return true;
        }
        else{
            return false;
        }
    }

 


更多专业前端知识,请上【猿2048】www.mk2048.com
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值