银行卡号算法

<!DOCTYPE html>
<html>
<body>

<h1>我的第一段 JavaScript</h1>

<p id="demo">
JavaScript 能改变 HTML 元素的内容。
</p>

<script>
function myFunction()
{
x=document.getElementById("demo");  // 找到元素
x.innerHTML="Hello JavaScript!";    // 改变内容
}


function checkcard(banknumber) {
        alert(banknumber);
        var banknumber="6214123456757169";
 alert(banknumber.length-1);
        //取出最后一位
        var last = banknumber.substr(banknumber.length-1,1);
        alert(banknumber.substr(banknumber.length-1,1));
        //前15或18位
        var front_last = banknumber.substr(0,banknumber.length-1);
        alert(front_last);
 
        var front_arr = new Array();
        //将前置部分号码存入数组(前15或18位)
        for(var i=front_last.length-1;i>-1;i--) {
            //前15或18位倒序存进数组
            front_arr.push(front_last.substr(i,1));
        }
 
        var sum1 = sum2 = sum3 = 0;
 
        for(var j=0;j<front_arr.length;j++) {
            if((j+1)%2==1) {
                // 奇数数字和
                if(parseInt(front_arr[j])*2<9) {
                    sum1 += parseInt(front_arr[j])*2;
                } else {
                    var str = parseInt(front_arr[j])*2;
                    var str1 = 1;
                    var str2 = str%10;
                    sum2 += str1;
                    sum2 += str2;
                }
            } else {
                // 偶数数字和
                sum3 += parseInt(front_arr[j]);
            }
        }
        var sum = sum1 + sum2 + sum3;
        var luhn = sum%10 == 0?0:10-sum%10;
 
        alert(luhn)
        if(luhn == parseInt(last)){
             alert("OK");
            return true;
           
        }else{
             alert("NG");
            return false;
        }
    }


</script>

<button type="button" onclick="myFunction()">点击这里1</button>
<button type="button" onclick="checkcard(6214123456787169)">点击这里2</button>

</body>
</html>

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值