js仿支付宝填写支付密码效果实现多方框输入密码


Posted in Javascript onMarch 09, 2016

不知道怎么描述标题,先看截图吧,大致的效果就是一个框输入一位密码。

js仿支付宝填写支付密码效果实现多方框输入密码

最开始实现的思路是一个小方框就是一个type为password的input,每输入一位自动跳到下一位,删除一位就自动跳到前一位,android上是OK的,很平滑也没有bug,但是ios上会出现键盘频繁调起和关闭,非常影响用户体验。原因估计是每个input会不断的focus和blur,每次focus会调起键盘,blur又会关闭键盘,so....此方案肯定不行了。

PM非要实现这种效果,木有办法~拗不过,一句用户体验不好会让你没话说,谁要咱是前端呢~拗不过就找解决方案吧。

既然多个是频繁focus和blur导致的问题,又必须是密码框,那何不就用一个input框来输入呢,小方框就用别的方式模拟,开干。

下面是实现的样式:

.pwd-box{
width:310px;
padding-left: 1px;
position: relative;
border: 1px solid #9f9fa0;
border-radius: 3px;
}
.pwd-box input[type="tel"]{
width: 99%;
height: 45px;
color: transparent;
position: absolute;
top: 0;
left: 0;
border: none;
font-size: 18px;
opacity: 0;
z-index: 1;
letter-spacing: 35px;
}
.fake-box input{
width: 44px;
height: 48px;
border: none;
border-right: 1px solid #e5e5e5;
text-align: center;
font-size: 30px;
}
.fake-box input:nth-last-child(1){
border:none;
}

.pwd-box .pwd-input:focus{//密码框聚焦的时候需要改变其位置,否则IOS上会有闪动的光标~
left:-1000px;
top: -100px;
}
var $input = $(".fake-box input");
      $("#pwd-input").on("input", function() {
        var pwd = $(this).val().trim();
        for (var i = 0, len = pwd.length; i < len; i++) {
          $input.eq("" + i + "").val(pwd[i]);
        }
        $input.each(function() {
          var index = $(this).index();
          if (index >= len) {
            $(this).val("");
          }
        });
        if (len == 6) {
          self.sendPackage(pwd);//发送密码
        }
      });

大致的思路就是动态监听真实密码框的输入修改小方框内密码框的内容。

其实效果实现不难,关键是思路还有解决该死的兼容,完成该效果的时候IOS会有闪动的光标,android没有,然后找一系列方法去隐藏光标,比如focus时候设置text-indent,color设置transparent等等,但都无济于事,后来发现淘宝有个办法是focus时候把密码框丢到一边去,因为外层有overflow hidden,完美解决了问题。

以上就是本文的全部内容,希望对大家学习javascript程序设计有所帮助。

Javascript 相关文章推荐
Jquery中扩展方法extend使用技巧
Aug 24 Javascript
jQuery validate验证插件使用详解
May 11 Javascript
AngularJS ng-app 指令实例详解
Jul 30 Javascript
通过修改360抢票的刷新频率和突破8车次限制实现方法
Jan 04 Javascript
js时间戳和c#时间戳互转方法(推荐)
Feb 15 Javascript
angular.js指令中的controller、compile与link函数的不同之处
May 10 Javascript
微信小程序Getuserinfo解决方案图解
Aug 24 Javascript
解决Vue.js父组件$on无法监听子组件$emit触发事件的问题
Sep 12 Javascript
Vue CLI 2.x搭建vue(目录最全分析)
Feb 27 Javascript
javascript(基于jQuery)实现鼠标获取选中的文字示例【测试可用】
Oct 26 jQuery
JS获取当前时间的年月日时分秒及时间的格式化的方法
Dec 18 Javascript
在微信小程序中渲染HTML内容3种解决方案及分析与问题解决
Jan 12 Javascript
jquery实现文本框textarea自适应高度
Mar 09 #Javascript
分享12个实用的jQuery代码片段
Mar 09 #Javascript
详解JavaScript正则表达式之分组匹配及反向引用
Mar 09 #Javascript
javascript html5移动端轻松实现文件上传
Mar 27 #Javascript
javascript事件绑定学习要点
Mar 09 #Javascript
js实现分割上传大文件
Mar 09 #Javascript
js实现ctrl+v粘贴上传图片(兼容chrome、firefox、ie11)
Mar 09 #Javascript
You might like
用PHP实现验证码功能
2006/10/09 PHP
PHP引用(&amp;)各种使用方法实例详解
2014/03/20 PHP
简单实用的PHP防注入类实例
2014/12/05 PHP
微信红包随机生成算法php版
2016/07/21 PHP
PHP获取数据库表中的数据插入新的表再原删除数据方法
2018/10/12 PHP
PHP的mysqli_ssl_set()函数讲解
2019/01/23 PHP
PHP cookie与session会话基本用法实例分析
2019/11/18 PHP
HTML5附件拖拽上传drop &amp; google.gears实现代码
2011/04/28 Javascript
js 完美图片新闻轮转效果,腾讯大粤网首页图片轮转改造而来
2011/11/21 Javascript
JS 添加网页桌面快捷方式的代码详细整理
2012/12/27 Javascript
jquery事件重复绑定的快速解决方法
2014/01/03 Javascript
详解JavaScript中的构造器Constructor模式
2016/01/14 Javascript
酷炫jQuery全屏3D焦点图动画效果
2016/03/22 Javascript
浅谈JavaScript中变量和函数声明的提升
2016/08/09 Javascript
EasyUI的doCellTip实现鼠标放到单元格上提示单元格内容
2016/08/24 Javascript
Vue.js每天必学之内部响应式原理探究
2016/09/07 Javascript
微信通过页面(H5)直接打开本地app的解决方法
2017/09/09 Javascript
详解PHP后期静态绑定分析与应用
2018/03/21 Javascript
vue定义全局变量和全局方法的方法示例
2018/08/01 Javascript
Angular封装搜索框组件操作示例
2019/04/25 Javascript
vue-cli基础配置及webpack配置修改的完整步骤
2019/10/20 Javascript
Django中实现一个高性能计数器(Counter)实例
2014/07/09 Python
使用Python中的greenlet包实现并发编程的入门教程
2015/04/16 Python
Python中的choice()方法使用详解
2015/05/15 Python
在Python中定义一个常量的方法
2018/11/10 Python
Python何时应该使用Lambda函数
2019/07/02 Python
python之拟合的实现
2019/07/19 Python
python pygame实现滚动横版射击游戏城市之战
2019/11/25 Python
简单了解python装饰器原理及使用方法
2019/12/18 Python
PyCharm 2020 激活到 2100 年的教程
2020/03/25 Python
完美解决pycharm 不显示代码提示问题
2020/06/02 Python
最新版 Windows10上安装Python 3.8.5的步骤详解
2020/11/28 Python
Omio意大利:全欧洲低价大巴、火车和航班搜索和比价
2017/12/02 全球购物
单位刻章介绍信范文
2014/01/11 职场文书
火锅店营销方案
2014/02/26 职场文书
教师纪律作风整顿心得体会
2016/01/23 职场文书