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

Posted 有梦想的乌龟·

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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>
 
 
 
 

以上是关于JS校验银行卡号输入卡号时放大效果的主要内容,如果未能解决你的问题,请参考以下文章

校验银行卡号

M1卡0扇区0块卡号校验问题懂的来

iOS 银行卡号有效性校验

Java代码校验银行卡号

Java代码校验银行卡号

Java实现银行卡号校验