jQuery实现6位数字密码输入框
下个月就要过年了,感觉有点瞎忙。翻了翻博客,感觉这个月都在打酱油啊。借口那么多,其实真的有点懒了,呵呵!
我争取在放假前,将自我总结以及来年计划发出来,把自己打造为勉族,不然真要浑噩度日了。
前几天,项目有个功能和某宝购物支付密码的输入框有点类似,就自己写了这篇博文,权当总结笔记吧。
啰嗦半天了,直接上代码:
结构层:
<div> <div>请在下方输入6位数字</div> <divclass="ipt-box-nick"> <inputtype="tel"maxlength="6"class="ipt-real-nick"/> <divclass="ipts-box-nick"> <divclass="ipt-fake-box"> <inputtype="text"> <inputtype="text"> <inputtype="text"> <inputtype="text"> <inputtype="text"> <inputtype="text"> </div> </div> <divclass="ipt-active-nick"><imgsrc="https://t.alipayobjects.com/images/rmsweb/T1nYJhXalXXXXXXXXX.gif"></div> </div> </div>
通过结构层,分析下大概思路:
本功能就是一个真实输入框和6个假输入框的故事。
- 将真实输入框和假输入框容器都定位重叠,注意将真实输入框的优先级设置较高,不然就输入不了咯。
- 为了做成看似假输入框在输入,则将真实输入框隐藏,用opacity隐藏哦。
- 用户输入时,通过行为层js将真实输入框的值分配给每个假输入框。
- 输入的同时,控制假输入框光标的效果,我用了一张某宝的图片做成的,实际上,假输入框是没有获取到焦点的。
注意:
这里真实输入框的type类型用的是tel,而不是number。因为后者会生成小箭头呀,前者在用户点击输入框时app判断type是tel就会弹出数字输入键盘更好。
表现层:
.ipt-box-nick{
height:40px!important;
line-height:40px!important;
position:relative!important;}
.ipt-box-nick.ipt-real-nick{
position:absolute!important;
top:0!important;
left:0!important;
width:100%;
height:40px!important;
line-height:40px!important;
opacity:0!important;
z-index:3!important;}
.ipt-box-nick.ipts-box-nick{
position:absolute!important;
top:0!important;
left:0!important;
z-index:1!important;
width:100%;
height:40px!important;
line-height:40px!important;
overflow:hidden;}
.ipt-box-nick.ipts-box-nick.ipt-fake-box{
height:40px!important;
line-height:40px!important;
display:flex!important;
justify-content:space-between!important;}
.ipt-box-nick.ipts-box-nick.ipt-fake-boxinput{
width:40px!important;
height:40px!important;
border:1pxsolid#D7D7D7!important;
color:#810213!important;
font-weight:bold!important;
font-size:18px!important;
text-align:center!important;
padding:0!important;}
.ipt-box-nick.ipt-active-nick{
width:40px!important;
height:40px!important;
line-height:40px!important;
text-align:center;
position:absolute!important;
top:0;
left:0;
z-index:2;}
.ipt-box-nick.ipt-active-nickimg{
vertical-align:middle;}
样式里面就一个定位重叠,一个隐藏真实输入框,我就不想多唠叨了。css我用sass写的,转译css有点乱,博友们将就看看吧。
行为层:
$(".ipt-real-nick").on("input",function(){
//console.log($(this).val());
var$input=$(".ipt-fake-boxinput");
if(!$(this).val()){//无值光标顶置
$('.ipt-active-nick').css('left',$input.eq(0).offset().left-parseInt($('.ipt-box-nick').parent().css('padding-left'))+'px');
}
if(/^[0-9]*$/g.test($(this).val())){//有值只能是数字
//console.log($(this).val());
varpwd=$(this).val().trim();
for(vari=0,len=pwd.length;i<len;i++){
$input.eq(i).val(pwd[i]);
if($input.eq(i).next().length){//模拟光标,先将图片容器定位,控制left值而已
$('.ipt-active-nick').css('left',$input.eq(i+1).offset().left-parseInt($('.ipt-box-nick').parent().css('padding-left'))+'px');
}
}
$input.each(function(){//将有值的当前input后的所有input清空
varindex=$(this).index();
if(index>=len){
$(this).val("");
}
});
if(len==6){
//执行其他操作
console.log('输入完整,执行操作');
}
}else{//清除val中的非数字,返回纯number的value
vararr=$(this).val().match(/\d/g);
$(this).val($(this).val().slice(0,$(this).val().lastIndexOf(arr[arr.length-1])+1));
//console.log($(this).val());
}
});
因为tel类型,在pc端兼容问题,所以加了点正则。
本身没有什么复杂的东西,我就不多啰嗦了,需要注意的地方都加注释了。
附上完整代码:
<!DOCTYPEhtml>
<html>
<head>
<metacharset="UTF-8">
<title>仿支付宝数字密码输入框</title>
<style>
.ipt-box-nick{
width:300px;
height:40px!important;
line-height:40px!important;
position:relative!important;}
.ipt-box-nick.ipt-real-nick{
position:absolute!important;
top:0!important;
left:0!important;
width:100%;
height:40px!important;
line-height:40px!important;
opacity:0!important;
z-index:3!important;}
.ipt-box-nick.ipts-box-nick{
position:absolute!important;
top:0!important;
left:0!important;
z-index:1!important;
width:100%;
height:40px!important;
line-height:40px!important;
overflow:hidden;}
.ipt-box-nick.ipts-box-nick.ipt-fake-box{
height:40px!important;
line-height:40px!important;
display:flex!important;
justify-content:space-between!important;}
.ipt-box-nick.ipts-box-nick.ipt-fake-boxinput{
width:40px!important;
height:38px!important;
border:1pxsolid#D7D7D7!important;
color:#810213!important;
font-weight:bold!important;
font-size:18px!important;
text-align:center!important;
padding:0!important;
border-radius:2px;}
.ipt-box-nick.ipt-active-nick{
width:40px!important;
height:40px!important;
line-height:40px!important;
text-align:center;
position:absolute!important;
top:0;
left:0;
z-index:2;}
.ipt-box-nick.ipt-active-nickimg{
vertical-align:middle;}
</style>
</head>
<body>
<div>
<divclass="lh40-nickh40-nickfwb-nick">请在下方输入6位数字</div>
<divclass="ipt-box-nickmb15-nick">
<inputtype="tel"maxlength="6"class="ipt-real-nick"/>
<divclass="ipts-box-nick">
<divclass="ipt-fake-box">
<inputtype="text">
<inputtype="text">
<inputtype="text">
<inputtype="text">
<inputtype="text">
<inputtype="text">
</div>
</div>
<divclass="ipt-active-nick"><imgsrc="https://t.alipayobjects.com/images/rmsweb/T1nYJhXalXXXXXXXXX.gif"></div>
</div>
</div>
<scriptsrc="https://cdn.bootcss.com/jquery/3.1.1/jquery.min.js"></script>
<script>
$(".ipt-real-nick").on("input",function(){
//console.log($(this).val());
var$input=$(".ipt-fake-boxinput");
if(!$(this).val()){//无值光标顶置
$('.ipt-active-nick').css('left',$input.eq(0).offset().left-parseInt($('.ipt-box-nick').parent().css('padding-left'))+'px');
}
if(/^[0-9]*$/g.test($(this).val())){//有值只能是数字
//console.log($(this).val());
varpwd=$(this).val().trim();
for(vari=0,len=pwd.length;i<len;i++){
$input.eq(i).val(pwd[i]);
if($input.eq(i).next().length){//模拟光标,先将图片容器定位,控制left值而已
$('.ipt-active-nick').css('left',$input.eq(i+1).offset().left-parseInt($('.ipt-box-nick').parent().css('padding-left'))+'px');
}
}
$input.each(function(){//将有值的当前input后的所有input清空
varindex=$(this).index();
if(index>=len){
$(this).val("");
}
});
if(len==6){
//执行其他操作
console.log('输入完整,执行操作');
}
}else{//清除val中的非数字,返回纯number的value
vararr=$(this).val().match(/\d/g);
$(this).val($(this).val().slice(0,$(this).val().lastIndexOf(arr[arr.length-1])+1));
//console.log($(this).val());
}
});
</script>
</body>
</html>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持毛票票!