jQuery实现6位数字密码输入框

发布时间 - 2026-01-10 22:12:20    点击率:

下个月就要过年了,感觉有点瞎忙。翻了翻博客,感觉这个月都在打酱油啊。借口那么多,其实真的有点懒了,呵呵!

  我争取在放假前,将自我总结以及来年计划发出来,把自己打造为勉族,不然真要浑噩度日了。

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

  啰嗦半天了,直接上代码:

结构层:

<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; }

样式里面就一个定位重叠,一个隐藏真实输入框,我就不想多唠叨了。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>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!


# jQuery  # 密码  # 输入框  # jQuery Easyui 验证两次密码输入是否相等  # jquery.cookie.js 操作cookie实现记住密码功能的实现代码  # JQuery记住用户名和密码的具体实现  # 基于JQuery的密码强度验证代码  # jquery判断输入密码两次是否相等  # 使用Jquery搭建最佳用户体验的登录页面之记住密码自动登录功能(含后台代码)  # IE下支持文本框和密码框placeholder效果的JQuery插件分享  # JQuery记住用户名密码实现下次自动登录功能  # jquery 实现密码框的显示与隐藏示例代码  # jquery 手势密码插件  # 我就  # 请在  # 将有  # 先将  # 清空  # 的是  # 就会  # 有个  # 都在  # 那么多  # 不多  # 较高  # 没有什么  # 半天  # 我用  # 用了  # 弹出  # 写了  # 这篇 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel Eloquent性能优化技巧_Laravel N+1查询问题解决  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  如何在云主机快速搭建网站站点?  如何快速搭建虚拟主机网站?新手必看指南  怎么用AI帮你为初创公司进行市场定位分析?  Laravel如何使用Service Container和依赖注入?(代码示例)  Laravel如何发送邮件和通知_Laravel邮件与通知系统发送步骤  手机钓鱼网站怎么制作视频,怎样拦截钓鱼网站。怎么办?  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  Laravel如何实现模型的全局作用域?(Global Scope示例)  laravel怎么在请求结束后执行任务(Terminable Middleware)_laravel Terminable Middleware请求结束任务执行方法  Laravel项目怎么部署到Linux_Laravel Nginx配置详解  千库网官网入口推荐 千库网设计创意平台入口  高防服务器租用如何选择配置与防御等级?  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  Laravel如何使用Service Provider注册服务_Laravel服务提供者配置与加载  使用C语言编写圣诞表白程序  做企业网站制作流程,企业网站制作基本流程有哪些?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  简单实现Android文件上传  如何快速生成高效建站系统源代码?  Laravel事件和监听器如何实现_Laravel Events & Listeners解耦应用的实战教程  Laravel怎么处理异常_Laravel自定义异常处理与错误页面教程  Laravel如何监控和管理失败的队列任务_Laravel失败任务处理与监控  Android自定义控件实现温度旋转按钮效果  英语简历制作免费网站推荐,如何将简历翻译成英文?  Laravel如何连接多个数据库_Laravel多数据库连接配置与切换教程  如何在阿里云香港服务器快速搭建网站?  北京的网站制作公司有哪些,哪个视频网站最好?  JS中对数组元素进行增删改移的方法总结  免费视频制作网站,更新又快又好的免费电影网站?  js实现获取鼠标当前的位置  如何在宝塔面板创建新站点?  深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?  Laravel如何使用Socialite实现第三方登录?(微信/GitHub示例)  如何彻底卸载建站之星软件?  如何有效防御Web建站篡改攻击?  Laravel如何与Docker(Sail)协同开发?(环境搭建教程)  如何在云主机上快速搭建网站?  Python正则表达式进阶教程_复杂匹配与分组替换解析  如何在七牛云存储上搭建网站并设置自定义域名?  php json中文编码为null的解决办法  php静态变量怎么调试_php静态变量作用域调试技巧【解答】  开心动漫网站制作软件下载,十分开心动画为何停播?  Laravel如何使用Gate和Policy进行授权?(权限控制)  Laravel如何安装使用Debugbar工具栏_Laravel性能调试与SQL监控插件【步骤】  零基础网站服务器架设实战:轻量应用与域名解析配置指南  打造顶配客厅影院,这份100寸电视推荐名单请查收  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  如何将凡科建站内容保存为本地文件?