下個月就要過年了,感覺有點瞎忙。翻了翻博客,感覺這個月都在打醬油啊。藉口那麼多,其實真的有點懶了,呵呵! 我爭取在放假前,將自我總結以及來年計劃發出來,把自己打造為勉族,不然真要渾噩度日了。 前幾天,項目有個功能和某寶購物支付密碼的輸入框有點類似,就自己寫了這篇博文,權當總結筆記吧。 啰嗦半天了,直 ...
下個月就要過年了,感覺有點瞎忙。翻了翻博客,感覺這個月都在打醬油啊。藉口那麼多,其實真的有點懶了,呵呵!
我爭取在放假前,將自我總結以及來年計劃發出來,把自己打造為勉族,不然真要渾噩度日了。
前幾天,項目有個功能和某寶購物支付密碼的輸入框有點類似,就自己寫了這篇博文,權當總結筆記吧。
啰嗦半天了,直接上代碼:
結構層:
<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個假輸入框的故事。
- 將真實輸入框和假輸入框容器都定位重疊,註意將真實輸入框的優先順序設置較高,不然就輸入不了咯。
- 為了做成看似假輸入框在輸入,則將真實輸入框隱藏,用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; }
View Code
樣式裡面就一個定位重疊,一個隱藏真實輸入框,我就不想多嘮叨了。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>View Code
效果演示:
回家擼的代碼和公司寫的時候有點出入,萬變不離其宗,效果出來就ok啦。
要過年咯,有個世界公敵已出現^_^一個'懶'字足矣打敗everybody!浪起來丫!