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

啰嗦半天了,直接上代码:
结构层:
<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>
效果演示:
以上所述是小编给大家介绍的JavaScript仿支付宝6位数字密码输入框,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# js
# 支付宝密码输入框
# js仿支付宝密码输入框
# 原生js实现密码输入框值的显示隐藏
# js模拟支付宝密码输入框
# JS中解决谷歌浏览器记住密码输入框颜色改变功能
# 基于JS实现类似支付宝支付密码输入框
# JavaScript实现输入框(密码框)出现提示语
# JavaScript仿支付宝密码输入框
# javascript实现仿银行密码输入框效果的代码
# vue.js实现只能输入数字的输入框
# Vue.js数字输入框组件使用方法详解
# JavaScript实现PC端四格密码输入框功能
# 输入框
# 我就
# 请在
# 将有
# 先将
# 支付宝
# 小编
# 清空
# 的是
# 就会
# 有个
# 在此
# 不多
# 较高
# 没有什么
# 半天
# 我用
# 用了
# 给大家
# 弹出
相关文章:
长沙做网站要多少钱,长沙国安网络怎么样?
如何在IIS中配置站点IP、端口及主机头?
如何通过多用户协作模板快速搭建高效企业网站?
如何通过VPS搭建网站快速盈利?
做企业网站制作流程,企业网站制作基本流程有哪些?
平台云上自主建站:模板化设计与智能工具打造高效网站
如何通过商城自助建站源码实现零基础高效建站?
建站之星CMS五站合一模板配置与SEO优化指南
电脑免费海报制作网站推荐,招聘海报哪个网站多?
如何快速搭建响应式可视化网站?
如何打造高效商业网站?建站目的决定转化率
佛山网站制作系统,佛山企业变更地址网上办理步骤?
相册网站制作软件,图片上的网址怎么复制?
黑客如何通过漏洞一步步攻陷网站服务器?
非常酷的网站设计制作软件,酷培ai教育官方网站?
如何制作一个表白网站视频,关于勇敢表白的小标题?
Swift开发中switch语句值绑定模式
如何正确下载安装西数主机建站助手?
动图在线制作网站有哪些,滑动动图图集怎么做?
Swift中循环语句中的转移语句 break 和 continue
如何在云主机上快速搭建多站点网站?
我的世界制作壁纸网站下载,手机怎么换我的世界壁纸?
高防服务器如何保障网站安全无虞?
网站制作话术技巧,网站推广做的好怎么话术?
深圳网站制作设计招聘,关于服装设计的流行趋势,哪里的资料比较全面?
公司网站制作需要多少钱,找人做公司网站需要多少钱?
在线ppt制作网站有哪些,请推荐几个好的课件下载的网站?
小说建站VPS选用指南:性能对比、配置优化与建站方案解析
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
建站之星五站合一营销型网站搭建攻略,流量入口全覆盖优化指南
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
完全自定义免费建站平台:主题模板在线生成一站式服务
杭州银行网站设计制作流程,杭州银行怎么开通认证方式?
香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南
建站中国必看指南:CMS建站系统+手机网站搭建核心技巧解析
建站主机与虚拟主机有何区别?如何选择最优方案?
,有什么在线背英语单词效率比较高的网站?
如何在Mac上搭建Golang开发环境_使用Homebrew安装和管理Go版本
网页设计与网站制作内容,怎样注册网站?
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
网站制作说明怎么写,简述网页设计的流程并说明原因?
高防服务器租用指南:配置选择与快速部署攻略
海南网站制作公司有哪些,海口网是哪家的?
昆明网站制作哪家好,昆明公租房申请网上登录入口?
如何在阿里云虚拟服务器快速搭建网站?
建站主机选虚拟主机还是云服务器更好?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
网站制作公司哪里好做,成都网站制作公司哪家做得比较好,更正规?
ppt在线制作免费网站推荐,有什么下载免费的ppt模板网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。