最后生成样子:

配置值:

  

* back {function} 回调函数
* msghtml {html} 自定义的html
* title {string|object} 标题
* {txt:标题,back:后退按钮}
* 字符串则只有标题,有back字段对象则有后退按钮
* sum {int} 输入的数字长度
* close {string} 关闭按钮的class类(有默认类名)
* cancel {string} 撤销重新输入按钮

js

 function ztkeyboard(options){
let create = function(){
this.options = {
'msghtml':options.msghtml||'',
'title':options.title||'',
'sum':options.sum,
'close':$(options.close)||'',
'cancel':$(options.cancel)||'',
};
this.init();
this.show();
this.click();
this.close();
this.delete();
};
create.prototype.init = () => {
let pd='';//密码长度
let keybord = '';//键盘按键
for(var i=0;i<options.sum;i++){
pd += `<span class="pd fl" dataval="">*</span>`;
};
for(var i=0;i<9;i++){
keybord+= `<div class="fl key"><a class="btn" href="javascript:;">${i+1}</a></div>`
}
$('body').append(
`<div id="keyboard-box" style='display:none'>
<div id="keyboard">
<div class="title">
<em class="fl back iconfont ${options.close}"></em>
<span class="tit-txt">
${options.title}
</span>
</div>
<div class="con-box fn-clear">
${pd}
</div>
${options.msghtml}
<div class="keybord fn-clear">
${keybord}
<div class="fl block"></div>
<div class="fl key"><a class="btn" href="javascript:;">0</a></div>
<div class="fl key close-keybord">
<a href="javascript:;" class="iconfont ${options.cancel}"></a>
</div>
</div>
</div>
</div>
`
);
// 防止冒泡
$('#keyboard-box').on('touchmove',function(e){
e.preventDefault();
})
};
// 键盘点击
create.prototype.click = () => {
$(".keybord .btn").on('click',function(){
let index = $('.pd.fl.sure').index();
let aim = $('.pd.fl.sure').length;
if(index!=-1&&aim<`${options.sum}`){
$('.pd.fl').eq(aim).addClass('sure').attr('val',this.text);
if(aim==`${options.sum}`-1){
let password = '';
$('.pd.fl').each(function(i,datas){
password+=$(datas).attr('val');
})
create.prototype.back(password);//使用回调
$('#keyboard-box').fadeOut(500,function(){
$('#keyboard-box').remove();//清除元素
});
}
}else if(index==-1){
$('.pd.fl').eq(0).addClass('sure').attr('val',this.text);
}
})
};
//撤销按钮
create.prototype.delete = () => {
$('.close-keybord .iconfont').on('click',function(){
let aim = $('.pd.fl.sure').length;
$('.pd.fl').eq(aim-1).removeClass('sure').attr('val','');
})
};
// 显示对象
create.prototype.show = () => {
$('#keyboard-box').fadeIn(500);
}
// 取消对象创建
create.prototype.close = () => {
$('#keyboard .title .back').on('click',function(){
$('#keyboard-box').fadeOut(100,function(){
$('#keyboard-box').remove();//清除元素
});
})
},
// 回调函数(传递输入的密码给前台)
create.prototype.back = (password) => {
typeof(options.back)==="function"?options.back(password):'undefined';
};
return new create();
}

html调用方法

        ztkeyboard({
msghtml:'<a class="forget-pwd" href="">忘记密码?</a>',
title:'请输入支付密码',
close:'icon-houtui',
sum:6,
cancel:'icon-chexiao',
back:function(data){
console.log(data)
console.log('提交支付密码表单')
}
})

css(less)

@r:75rem;
@basecolor:#51d392;
/* 方法库 */
@import url("http://at.alicdn.com/t/font_903282_qp1m330oew.css");
#keyboard-box{
position: fixed;
display: block;
width: 100%;
left:;
top:;
height: 100%;
background-color: rgba(0,0,0,0.2);
#keyboard{
position: absolute;
bottom:;
width: 100%;
height: 880/@r;
left:;
background-color: #fff;
.title{
line-height: 92/@r;
border-bottom: 1px solid #cacaca;
position: relative;
box-sizing: border-box;
.fl{
position: absolute;
font-size:34/@r;
color: #939395;
padding-left: 40/@r;
}
.tit-txt{
font-size: 38/@r;
color: #333;
text-align: center;
display: block; }
}
.con-box{
margin: 48/@r 32/@r 0 32/@r;
display:flex;
height: 94/@r;
border: 1px solid #a2a2a4;
border-radius: 10/@r;
.pd{
flex-grow:;
text-align: center;
font-size: 60/@r;
line-height: 94/@r;
color: #fff;
}
.pd:not(:last-child){
border-right: 1px solid #a2a2a4;
}
.pd.sure{
flex-grow:;
text-align: center;
font-size: 60/@r;
line-height: 94/@r;
color: #333;
}
}
.forget-pwd{
margin-top: 36/@r;
margin-bottom: 150/@r;
color: #0e8fe2;
display: block;
text-align: center;
}
.keybord{
padding: 12/@r 12/@r 4/@r 12/@r;
background-color: #d0d3da;
.fl{
width: 33%;
height: 92/@r;
display: inline-block;
text-align: center;
color: #333;
padding-bottom: 12/@r;
line-height: 92/@r;
cursor: pointer;
font-size:40/@r;
}
.btn{
display: block;
border-radius: 10/@r;
height: 92/@r;
line-height: 92/@r;
background-color: #fff;
margin: 0 6/@r;
color: #333;
box-shadow: 0px 10/@r 10/@r #88878c;
}
.close-keybord .iconfont{
color: #333;
font-size:60/@r;
display: block;
}
}
}
}

移动端键盘密码输入框插件(jquery用于支付密码)的更多相关文章

  1. 移动端下滑刷新插件(jQuery插件)

    由于在工作不能独自开发,而且为了给他们方便,自己写过不少的插件,不过今天刚好空闲,发出刚好完成的,移动端的下滑到底刷新插件.我不是很喜欢写插件给别人用,因为用起来自然是简单的,没什么难度,所以一起分享 ...

  2. 移动端多选插件-jquery

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  3. 移动端触摸滑动插件Swiper

    移动端触摸滑动插件Swiper 04/02/2015 一.了解Swiper 目前移动端项目一般都需要具有触屏焦点图的效果,如果你也需要实现这一功能的话,Swiper是一个不错的选择. 1.他不需要加载 ...

  4. jQuery文件上传插件jQuery Upload File 有上传进度条

    jQuery文件上传插件jQuery Upload File 有上传进度条 jQuery文件上传插件jQuery Upload File,插件使用简单,支持单文件和多文件上传,支持文件拖拽上传,有进度 ...

  5. 基于zepto的移动端轻量级日期插件

    前言 做过移动Web开发的同学都知道,移动端日期选择是很常见的需求.在PC端,我们有很丰富的选择,比较出名的就有Mobiscroll和jQuery UI Datepicker.个人看来,这些插件存在的 ...

  6. 动态生成二维码插件 jquery.qrcode.js

    前段时间做项目,需要动态生成一个二维码,于是就在网上找了一下发现一个jquery插件jquery.qrcode.js,所以今天就简单说一下这个插件的使用: jquery.qrcode.js是依赖jqu ...

  7. 纯原生js移动端城市选择插件

    接着上一篇纯js移动端日期选择插件,话说今天同事又来咨询省市县联动的效果在移动端中如何实现,还是老样子,百度上一搜,诶~又全是基于jquery.zepto的,更加可恨的是大多数都是PC版的,三个sel ...

  8. jQuery响应式幻灯片插件jquery.glide.js(支持触摸&轻量级)

    找到一款好的幻灯片插件不容易,找到一款功能全并且使用很简单的幻灯片更不容易,今天为大家分享一款全能的幻灯片插件glide.js,也是我现在在使用的一款插件. jquery.glide.js是响应和触摸 ...

  9. jQuery懒加载插件jquery.lazyload.js使用说明实例

    jQuery懒加载插件jquery.lazyload.js使用说明实例很多网站都会用到‘图片懒加载’这种方式对网站进行优化,即延迟加载图片或符合某些条件才开始加载图片.懒加载原理:浏览器会自动对页面中 ...

随机推荐

  1. PostgreSql 使用dblink跨库

    此篇介绍下psql下dblink的使用方式,帮助自己记录以备后需.dblink是psql下的扩展功能,可以实现在一个数据库中远程操作另外一个数据库,是实现跨库的一种方法.下面步入正文. 安装dblin ...

  2. 微服务与RPC

    1.微服务架构 1.1 特征 自动化部署,端点智能化,语言和数据的去中心化控制. 1.2架构 一种将一个单一应用程序开发为一组小型服务的方法,每个服务运行在自己的进程中,服务间通信采用轻量级通信机制( ...

  3. MySQL教程之concat以及group_concat的用法

    本文中使用的例子均在下面的数据库表tt2下执行: 一.concat()函数 1.功能:将多个字符串连接成一个字符串. 2.语法:concat(str1, str2,...) 返回结果为连接参数产生的字 ...

  4. C++ 之 简单的五子棋AI程序

    本人是大一新生,寒假无聊,抱着试试看的心态(没有想到可以完成),写了C++的简单五子棋程序,开心.     下面是效果图:     一.首先讲讲大致思路.            五子棋实现的基础:  ...

  5. 从壹开始前后端分离 [ Vue2.0+.NET Core2.1] 二十二║Vue实战:个人博客第一版(axios+router)

    前言 今天正式开始写代码了,之前铺垫了很多了,包括 6 篇基础文章,一篇正式环境搭建,就是为了今天做准备,想温习的小伙伴可以再看看<Vue 基础入门+详细的环境搭建>,内容很多,这里就暂时 ...

  6. JS中some()和every()和join()和concat()和pop(),push(),shift(),unshfit()和map()和filter()

    一.Array 1.some()和every() some()是对数组中每一项运行指定函数,如果该函数对任一项返回true,则返回true. every()是对数组中的每一项运行给定函数,如果该函数对 ...

  7. Nodejs+Express 搭建 web应用

    简单的记录下关于如何使用nodejs+Express 极速搭建一个web应用. 项目所需,要用到nodejs,那就去学咯.简单的看了下 七天学会NodeJS,Node.js 教程.发现其实好简单的,分 ...

  8. 死磕 java集合之CopyOnWriteArraySet源码分析——内含巧妙设计

    问题 (1)CopyOnWriteArraySet是用Map实现的吗? (2)CopyOnWriteArraySet是有序的吗? (3)CopyOnWriteArraySet是并发安全的吗? (4)C ...

  9. 区块链技术现状&前景

    炒作周期 Gartner 在 2017 年发布的新兴技术炒作曲线,这张图是去年 8 月发布的,当时估计它们也没料到随后能有那么火,当时区块链在这个位置,其实是已经过了炒作的巅峰期,正在往低谷走的这个阶 ...

  10. Docker进阶之七:管理应用程序数据

    管理应用程序数据:Volume Docker提供三种不同的方式将数据从宿主机挂载到容器中:volumes,bind mounts和tmpfs. volumes:Docker管理宿主机文件系统的一部分( ...