javascript学习指南_JavaScript实现仿支付宝6位数字密码输入框的教程

时间:2020-12-18  来源:班主任工作总结  阅读:

前几天,项目有个功能和某宝购物支付密码的输入框有点类似,就自己写了这篇博文,权当总结笔记吧。

??掳胩炝耍?苯由洗?耄?/p>

结构层:

  请在下方输入6位数字                                                    

通过结构层,分析下大概思路:

本功能就是一个真实输入框和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-box input {   width: 40px !important;   height: 40px !important;   border: 1px solid#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-nick img {   vertical-align: middle; }

  样式里面就一个定位重叠,一个隐藏真实输入框,我就不想多唠叨了。css我用sass写的,转译css有点乱,博友们将就看看吧。

 行为层:

$(".ipt-real-nick").on("input",function() {   //console.log($(this).val());   var$input = $(".ipt-fake-box input");   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端兼容问题,所以加了点正则。

本身没有什么复杂的东西,我就不多??铝耍?枰?⒁獾牡胤蕉技幼⑹土恕?/p>

附上完整代码:

   仿支付宝数字密码输入框    请在下方输入6位数字                                                       <script src="//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-box input");   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>

效果演示:

javascript学习指南_JavaScript实现仿支付宝6位数字密码输入框的教程

http://m.bbyears.com/banzhurengongzuo/117295.html

推荐访问:
相关阅读 猜你喜欢
本类排行 本类最新