时间:2021-05-26
下个月就要过年了,感觉有点瞎忙。翻了翻博客,感觉这个月都在打酱油啊。借口那么多,其实真的有点懒了,呵呵!
我争取在放假前,将自我总结以及来年计划发出来,把自己打造为勉族,不然真要浑噩度日了。
前几天,项目有个功能和某宝购物支付密码的输入框有点类似,就自己写了这篇博文,权当总结笔记吧。
啰嗦半天了,直接上代码:
结构层:
<div> <div>请在下方输入6位数字</div> <div class="ipt-box-nick"> <input type="tel" maxlength="6" class="ipt-real-nick"/> <div class="ipts-box-nick"> <div class="ipt-fake-box"> <input type="text" > <input type="text" > <input type="text" > <input type="text" > <input type="text" > <input type="text" > </div> </div> <div class="ipt-active-nick"><img src="https://t.alipayobjects.com/images/rmsweb/T1nYJhXalXXXXXXXXX.gif"></div> </div> </div>通过结构层,分析下大概思路:
本功能就是一个真实输入框和6个假输入框的故事。
注意:
这里真实输入框的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()); var pwd = $(this).val().trim(); for (var i = 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清空 var index = $(this).index(); if (index >= len) { $(this).val(""); } }); if (len == 6) { //执行其他操作 console.log('输入完整,执行操作'); } }else{//清除val中的非数字,返回纯number的value var arr=$(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端兼容问题,所以加了点正则。
本身没有什么复杂的东西,我就不多啰嗦了,需要注意的地方都加注释了。
附上完整代码:
<!DOCTYPE html><html><head> <meta charset="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-box input { width: 40px !important; height: 38px !important; border: 1px solid #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-nick img { vertical-align: middle; } </style></head><body><div> <div class="lh40-nick h40-nick fwb-nick">请在下方输入6位数字</div> <div class="ipt-box-nick mb15-nick"> <input type="tel" maxlength="6" class="ipt-real-nick"/> <div class="ipts-box-nick"> <div class="ipt-fake-box"> <input type="text" > <input type="text" > <input type="text" > <input type="text" > <input type="text" > <input type="text" > </div> </div> <div class="ipt-active-nick"><img src="https://t.alipayobjects.com/images/rmsweb/T1nYJhXalXXXXXXXXX.gif"></div> </div></div><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()); var pwd = $(this).val().trim(); for (var i = 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清空 var index = $(this).index(); if (index >= len) { $(this).val(""); } }); if (len == 6) { //执行其他操作 console.log('输入完整,执行操作'); } }else{//清除val中的非数字,返回纯number的value var arr=$(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>以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
前几天,项目有个功能和某宝购物支付密码的输入框有点类似,就自己写了这篇博文,权当总结笔记吧。 啰嗦半天了,直接上代码:结构层:请在下方输入6位数字通过结构
废话不多说了,具体代码如下所示:angular表单校验span{color:red;}用户名*只能输入数字最少为6位数密码*最少为6位数确认密码*XOK手机*只
iPhone12四位数密码设置方法在手机设置菜单中点击【面容ID及密码】。输入锁屏密码后点击【更改密码】。输入旧密码,点击下方的【密码选项】,选择【4位数字密码
本文实例为大家分享了Vue.js数字输入框组件的具体实现代码,供大家参考,具体内容如下效果入口页index.html数字输入框组件数字输入框组件input-nu
需要实现的效果:一个输入框,当输入框未获得焦点的时候,value值为“密码”;当输入框失去焦点的时候,输入内容显示为”*****”我们很直接会想到下面的js$(