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寸电视推荐名单请查收
厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?
如何将凡科建站内容保存为本地文件?

