jQuery實(shí)現(xiàn)6位數(shù)字密碼輸入框
下個(gè)月就要過(guò)年了,感覺(jué)有點(diǎn)瞎忙。翻了翻博客,感覺(jué)這個(gè)月都在打醬油啊。借口那么多,其實(shí)真的有點(diǎn)懶了,呵呵!
我爭(zhēng)取在放假前,將自我總結(jié)以及來(lái)年計(jì)劃發(fā)出來(lái),把自己打造為勉族,不然真要渾噩度日了。
前幾天,項(xiàng)目有個(gè)功能和某寶購(gòu)物支付密碼的輸入框有點(diǎn)類似,就自己寫(xiě)了這篇博文,權(quán)當(dāng)總結(jié)筆記吧。
啰嗦半天了,直接上代碼:
結(jié)構(gòu)層:
<div> <div>請(qǐng)?jiān)谙路捷斎?位數(shù)字</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>
通過(guò)結(jié)構(gòu)層,分析下大概思路:
本功能就是一個(gè)真實(shí)輸入框和6個(gè)假輸入框的故事。
- 將真實(shí)輸入框和假輸入框容器都定位重疊,注意將真實(shí)輸入框的優(yōu)先級(jí)設(shè)置較高,不然就輸入不了咯。
- 為了做成看似假輸入框在輸入,則將真實(shí)輸入框隱藏,用opacity隱藏哦。
- 用戶輸入時(shí),通過(guò)行為層js將真實(shí)輸入框的值分配給每個(gè)假輸入框。
- 輸入的同時(shí),控制假輸入框光標(biāo)的效果,我用了一張某寶的圖片做成的,實(shí)際上,假輸入框是沒(méi)有獲取到焦點(diǎn)的。
注意:
這里真實(shí)輸入框的type類型用的是tel,而不是number。因?yàn)楹笳邥?huì)生成小箭頭呀,前者在用戶點(diǎn)擊輸入框時(shí)app判斷type是tel就會(huì)彈出數(shù)字輸入鍵盤(pán)更好。
表現(xiàn)層:
.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; }
樣式里面就一個(gè)定位重疊,一個(gè)隱藏真實(shí)輸入框,我就不想多嘮叨了。css我用sass寫(xiě)的,轉(zhuǎn)譯css有點(diǎn)亂,博友們將就看看吧。
行為層:
$(".ipt-real-nick").on("input", function() { //console.log($(this).val()); var $input = $(".ipt-fake-box input"); if(!$(this).val()){//無(wú)值光標(biāo)頂置 $('.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())){//有值只能是數(shù)字 //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){//模擬光標(biāo),先將圖片容器定位,控制left值而已 $('.ipt-active-nick').css('left',$input.eq(i+1).offset().left-parseInt($('.ipt-box-nick').parent().css('padding-left'))+'px'); } } $input.each(function() {//將有值的當(dāng)前input后的所有input清空 var index = $(this).index(); if (index >= len) { $(this).val(""); } }); if (len == 6) { //執(zhí)行其他操作 console.log('輸入完整,執(zhí)行操作'); } }else{//清除val中的非數(shù)字,返回純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()); } });
因?yàn)閠el類型,在pc端兼容問(wèn)題,所以加了點(diǎn)正則。
本身沒(méi)有什么復(fù)雜的東西,我就不多啰嗦了,需要注意的地方都加注釋了。
附上完整代碼:
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>仿支付寶數(shù)字密碼輸入框</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">請(qǐng)?jiān)谙路捷斎?位數(shù)字</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="http://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()){//無(wú)值光標(biāo)頂置 $('.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())){//有值只能是數(shù)字 //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){//模擬光標(biāo),先將圖片容器定位,控制left值而已 $('.ipt-active-nick').css('left',$input.eq(i+1).offset().left-parseInt($('.ipt-box-nick').parent().css('padding-left'))+'px'); } } $input.each(function() {//將有值的當(dāng)前input后的所有input清空 var index = $(this).index(); if (index >= len) { $(this).val(""); } }); if (len == 6) { //執(zhí)行其他操作 console.log('輸入完整,執(zhí)行操作'); } }else{//清除val中的非數(shù)字,返回純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>
以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助,同時(shí)也希望多多支持腳本之家!
- jQuery Easyui 驗(yàn)證兩次密碼輸入是否相等
- jquery.cookie.js 操作cookie實(shí)現(xiàn)記住密碼功能的實(shí)現(xiàn)代碼
- JQuery記住用戶名和密碼的具體實(shí)現(xiàn)
- 基于JQuery的密碼強(qiáng)度驗(yàn)證代碼
- jquery判斷輸入密碼兩次是否相等
- 使用Jquery搭建最佳用戶體驗(yàn)的登錄頁(yè)面之記住密碼自動(dòng)登錄功能(含后臺(tái)代碼)
- IE下支持文本框和密碼框placeholder效果的JQuery插件分享
- JQuery記住用戶名密碼實(shí)現(xiàn)下次自動(dòng)登錄功能
- jquery 實(shí)現(xiàn)密碼框的顯示與隱藏示例代碼
- jquery 手勢(shì)密碼插件
相關(guān)文章
jQuery+ajax實(shí)現(xiàn)頂一下,踩一下效果
很多網(wǎng)站上面有頂一下,踩一下效果是直接用別人做好的插件放上去的,上星期正好要用到這個(gè)效果,就去研究了下。下面就一步一步來(lái)實(shí)現(xiàn)整個(gè)效果。。。。2010-07-07jQuery選擇器源碼解讀(五):tokenize的解析過(guò)程
這篇文章主要介紹了jQuery選擇器源碼解讀(五):tokenize的解析過(guò)程,本文用詳細(xì)的注釋解讀了tokenize方法的解析過(guò)程,需要的朋友可以參考下2015-03-03統(tǒng)計(jì)jQuery中各字符串出現(xiàn)次數(shù)的工具
如果使用一個(gè)變量替換,使用工具壓縮時(shí)將會(huì)進(jìn)一步減少文件的大小2012-05-05實(shí)例詳解jQuery結(jié)合GridView控件的使用方法
這篇文章主要以實(shí)例的方式詳細(xì)介紹了jQuery結(jié)合GridView控件的使用方法,感興趣的小伙伴們可以參考一下2016-01-01jQuery ajax 當(dāng)async為false時(shí)解決同步操作失敗的問(wèn)題
這篇文章主要介紹了 jQuery ajax 當(dāng)async為false時(shí)解決同步操作失敗的問(wèn)題的相關(guān)資料,需要的朋友可以參考下2016-11-11EasyUi 打開(kāi)對(duì)話框后控件賦值及賦值后不顯示的問(wèn)題解決辦法
這篇文章主要介紹了easyUi 打開(kāi)對(duì)話框后控件賦值,以及賦值后不顯示的問(wèn)題解決辦法,解決方法非常簡(jiǎn)單,只需要將賦值語(yǔ)句修改下就好,下面小編給大家簡(jiǎn)單介紹下,需要的朋友參考下2017-01-01jquery+ajax驗(yàn)證不通過(guò)也提交表單問(wèn)題處理
這篇文章主要介紹了jquery validationEngine中使用ajax驗(yàn)證不通過(guò)也提交表單問(wèn)題處理,需要的朋友可以參考下2014-12-12js jquery獲取隨機(jī)生成id的服務(wù)器控件的三種方法
由于ASP.NET網(wǎng)頁(yè)運(yùn)行后,服務(wù)器控件會(huì)隨機(jī)生成客戶端id,jquery獲取時(shí)候不太好操作,下面為大家整理了三種方法,感興趣的朋友可以參考下哈,希望對(duì)大家有所幫助2013-07-07