• JS校验银行卡号、输入卡号时放大效果


    一、(校验格式)
     
    function CheckBankNo(t_bankno) {
      var bankno = $.trim(t_bankno);
      if(bankno == "") {
      layer.msg("请填写银行卡号");
      return false;
    }
    if(bankno.length < 16 || bankno.length > 19) {
      layer.msg("银行卡号长度必须在16到19之间");
      return false;
    }
    var num = /^d*$/; //全数字
    if(!num.exec(bankno)) {
      layer.msg("银行卡号必须全为数字");
      return false;
    }
    //开头6位
    var strBin = "10,18,30,35,37,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,58,60,62,65,68,69,84,87,88,94,95,98,99";
    if(strBin.indexOf(bankno.substring(0, 2)) == -1) {
      layer.msg("银行卡号开头6位不符合规范");
      return false;
    }
    //Luhm校验(新)
    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])%10);
      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)%10==0?10:parseInt(sumTotal)%10;
    var luhm= 10-k;
    if(lastNum==luhm){
      return true;
    }
    else{
      layer.msg("银行卡号不符合规范");
      return false;
    }
    }
     
     
     
     
    二、(输入时放大)
     
    //1、CSS:放大的样式
     
    <style>
    .inputCard-wrap {
    position: relative;
    }
     
    .inputCard-wrap .panelCard {
    display: none;
    position: absolute;
    top: -30px;
    left: 79px;
    z-index: 100;
     
    border: 1px #ffce6e solid;
    padding: 10px;
    height: 8px;
    font-size: 1.7em;
    line-height: 8px;
    color: #585858;
    }
    </style>
     
     
    //2、内容:
     
    <div class="divfirst inputCard-wrap">
    银行卡号:
    <input type="text" name="bankCardNumber" class="input-text size-S inputCard"
    id="bankCardNumber"
    style="margin-left: 5px;" placeholder="输入银行卡号">
    <div class="panelCard"></div>
    </div>
     
     
    //3、JS:
     
    <script>
    $(function () {
    /* 银行卡号实时验证放大显示 */
    $(".inputCard").keyup(function (e) {
      var self = $.trim(e.target.value),
      parent = $(e.target).closest(".inputCard-wrap"),
      panel = $(".panelCard", parent),
      val = self.replace(/D/g, '');
    if (self.length > 19) {
      this.value = self.substr(0, 19);
      return this.value;
    }
    if (val == self) {
      panel.show();
      val = self.replace(/(....)(?=.)/g, '$1 ');
      panel.html(val);
    } else {
      panel.hide();
      return self;
    }
    });
    $(".inputCard").unbind('focusin');
    $(".inputCard").bind('focusin', function (e) {
    var self = $.trim(e.target.value),
    parent = $(e.target).closest(".inputCard-wrap"),
    panel = $(".panelCard", parent),
    val = self.replace(/(....)(?=.)/g, '$1 ');
    if (val != '') {
      panel.show();
      panel.html(val);
    }
    });
    $(".inputCard").unbind('focusout');
    $(".inputCard").bind('focusout', function (e) {
      var parent = $(e.target).closest(".inputCard-wrap"),
      panel = $(".panelCard", parent);
      panel.hide();
    });
    })
    </script>
     
     
     
     
    作者:有梦想的乌龟·
  • 相关阅读:
    C基础--指针数组
    C基础--函数指针作为函数的参数
    C基础--二重指针和数组指针
    C基础--泛型函数
    html中怎么去掉input获取焦点时候的边框
    CSS3阴影 box-shadow的使用和技巧总结
    jQuery 事件
    jquery $(document).ready() 与window.onload的区别
    JavaScript substring() 方法
    indexOf()的用法
  • 原文地址:https://www.cnblogs.com/nlbnick/p/6940801.html
Copyright © 2020-2023  润新知