原生js写个简单的数字键盘(by vczero)

一、起因

  最近支付的同事说,数字键盘有些问题;在移动设备上有时候比较难出现点(.) 和数字在一起的格局;因此,考虑到这种情况,就建议手写个模拟键盘了。花了一晚上的时间,写了个简单的键盘,基本能用。考虑到有的开发者没有使用juqery,就使用原生的js了。

  Github地址:https://github.com/vczero/keyboard

二、截图如下

三、体验地址(需要点击input才能弹出数字键盘的哦)

URL: http://vczero.github.io/num_key/index.html

当然可以扫二维码:

三、代码比较简单,直接贴了

 1 ;(function(exports){
 2     var KeyBoard = function(input, options){
 3         var body = document.getElementsByTagName(‘body‘)[0];
 4         var DIV_ID = options && options.divId || ‘__w_l_h_v_c_z_e_r_o_divid‘;
 5
 6         if(document.getElementById(DIV_ID)){
 7             body.removeChild(document.getElementById(DIV_ID));
 8         }
 9
10         this.input = input;
11         this.el = document.createElement(‘div‘);
12
13         var self = this;
14         var zIndex = options && options.zIndex || 1000;
15         var width = options && options.width || ‘100%‘;
16         var height = options && options.height || ‘193px‘;
17         var fontSize = options && options.fontSize || ‘15px‘;
18         var backgroundColor = options && options.backgroundColor || ‘#fff‘;
19         var TABLE_ID = options && options.table_id || ‘table_0909099‘;
20         var mobile = typeof orientation !== ‘undefined‘;
21
22         this.el.id = DIV_ID;
23         this.el.style.position = ‘absolute‘;
24         this.el.style.left = 0;
25         this.el.style.right = 0;
26         this.el.style.bottom = 0;
27         this.el.style.zIndex = zIndex;
28         this.el.style.width = width;
29         this.el.style.height = height;
30         this.el.style.backgroundColor = backgroundColor;
31
32         //样式
33         var cssStr = ‘<style type="text/css">‘;
34         cssStr += ‘#‘ + TABLE_ID + ‘{text-align:center;width:100%;height:160px;border-top:1px solid #CECDCE;background-color:#FFF;}‘;
35         cssStr += ‘#‘ + TABLE_ID + ‘ td{width:33%;border:1px solid #ddd;border-right:0;border-top:0;}‘;
36         if(!mobile){
37             cssStr += ‘#‘ + TABLE_ID + ‘ td:hover{background-color:#1FB9FF;color:#FFF;}‘;
38         }
39         cssStr += ‘</style>‘;
40
41         //Button
42         var btnStr = ‘<div style="width:60px;height:28px;background-color:#1FB9FF;‘;
43         btnStr += ‘float:right;margin-right:5px;text-align:center;color:#fff;‘;
44         btnStr += ‘line-height:28px;border-radius:3px;margin-bottom:5px;cursor:pointer;">完成</div>‘;
45
46         //table
47         var tableStr = ‘<table id="‘ + TABLE_ID + ‘" border="0" cellspacing="0" cellpadding="0">‘;
48             tableStr += ‘<tr><td>1</td><td>2</td><td>3</td></tr>‘;
49             tableStr += ‘<tr><td>4</td><td>5</td><td>6</td></tr>‘;
50             tableStr += ‘<tr><td>7</td><td>8</td><td>9</td></tr>‘;
51             tableStr += ‘<tr><td style="background-color:#D3D9DF;">.</td><td>0</td>‘;
52             tableStr += ‘<td style="background-color:#D3D9DF;">删除</td></tr>‘;
53             tableStr += ‘</table>‘;
54         this.el.innerHTML = cssStr + btnStr + tableStr;
55
56         function addEvent(e){
57             var ev = e || window.event;
58             var clickEl = ev.element || ev.target;
59             var value = clickEl.textContent || clickEl.innerText;
60             if(clickEl.tagName.toLocaleLowerCase() === ‘td‘ && value !== "删除"){
61                 if(self.input){
62                     self.input.value += value;
63                 }
64             }else if(clickEl.tagName.toLocaleLowerCase() === ‘div‘ && value === "完成"){
65                 body.removeChild(self.el);
66             }else if(clickEl.tagName.toLocaleLowerCase() === ‘td‘ && value === "删除"){
67                 var num = self.input.value;
68                 if(num){
69                     var newNum = num.substr(0, num.length - 1);
70                     self.input.value = newNum;
71                 }
72             }
73         }
74
75         if(mobile){
76             this.el.ontouchstart = addEvent;
77         }else{
78             this.el.onclick = addEvent;
79         }
80         body.appendChild(this.el);
81     }
82
83     exports.KeyBoard = KeyBoard;
84
85 })(window);

四、简单demo

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8" />
 5         <title>模拟数字键盘</title>
 6         <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, minimal-ui" />
 7     </head>
 8     <body>
 9         <div>
10             <input id="text1" readonly="readonly" type="number" style="height:28px;width:98%;outline:none;border:1px solid #1AB6FF;padding-left:3px;"/>
11             <br />
12             <br />
13             <input id="text2" readonly="readonly" type="number" style="height:28px;width:98%;outline:none;border:1px solid #1AB6FF;padding-left:3px;"/>
14         </div>
15         <script type="text/javascript" src="keyboard.js"></script>
16         <script type="text/javascript">
17         (function(){
18             var input1 = document.getElementById(‘text1‘);
19             var input2 = document.getElementById(‘text2‘);
20
21             input1.onclick = function(){
22                 new KeyBoard(input1);
23             };
24
25             input2.onclick = function(){
26                 new KeyBoard(input2);
27             };
28
29
30         })();
31         </script>
32     </body>
33 </html>
时间: 2024-10-13 04:37:06

原生js写个简单的数字键盘(by vczero)的相关文章

用原生JS写移动动画案例及实际应用

js很强大 相信很多人都知道,那么它有哪些强大之处呢?有兴趣的人可以去查查,这里就不赘述了,因为不在本片文章讨论的范围. 我们要讲的是怎么用原生JS写移动动画?我们先举一个最简单的动画例子,很多网站的左边或右边会有个分享的框,鼠标放上去就还移出一个列表,里面是要分享的地址.鼠标移开,就会移进去. 要实现这个效果要怎么做呢? 可以想一想,鼠标经过和鼠标离开很好理解 用onmousemove事件和onmouseout事件就能完成. 那移动动画呢?我们可以一步一步思考, 首先,一开始是这样的 完成移动

原生JS写的ajax函数

参照JQuery中的ajax功能,用原生JS写了一个ajax,功能相对JQuery要少很多,不过基本功能都有,包括JSONP. 调用的方式分为两种: 1. ajax(url, {}); 2. ajax({}); 调用的方法参照JQuery的ajax,只是 不需要写$.ajax ,只需要写 ajax 就可以了. 代码如下: !function () { var jsonp_idx = 1; return ajax = function (url, options) { if (typeof url

原生js写的一个弧形菜单插件

弧形菜单是一种半弧式或者全弧形菜单,是一种不同于传统横向或者竖向菜单形式的菜单.最近在网上看到好多人写出了这种效果,于是也尝试自己写了一个. 实现方式:原生态js 主要结构: 1.参数合并 1 var defaultPra = { 2 mainMenuId: "ArcMenu",//主菜单id 3 menuBoxId:"menuBox",//菜单包裹id 4 position: "",//弧形菜单 5 customPosition:"0

分享:计算机图形学期末作业!!利用WebGL的第三方库three.js写一个简单的网页版“我的世界小游戏”

这几天一直在忙着期末考试,所以一直没有更新我的博客,今天刚把我的期末作业完成了,心情澎湃,所以晚上不管怎么样,我也要写一篇博客纪念一下我上课都没有听,还是通过强大的度娘完成了我的作业的经历.(当然作业不是百度来的,我只是百度了一些示例代码的意思,怎么用!算了,越解释万一越黑呢!哈哈O(∩_∩)O哈哈~) ----------------------------------------------------------------分界线------------------------------

原生js写的贪吃蛇网页版游戏

<html> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>原生js写的贪吃蛇网页版游戏</title> </head> <body><div><A href="http://www.999jiujiu.com/">h

原生js做一个简单的进度条

用原生js做进度条,布局非常简单,一个盒子里放一个span标签,让它的宽度为0,并且转成块元素. 主要用定时器动态增加span的宽度,并且当它的宽度大于父级盒子的宽度的时候停止 效果如下: 一 css如下: *{ margin: 0; padding: 0; } #box{ width: 500px; height: 30px; margin: 50px auto; overflow: hidden; border: 1px solid #CCCCCC; border-radius: 15px;

使用原生js写ajax

// 使用原生js 封装ajax // 兼容xhr对象 function createXHR(){ if(typeof XMLHttpRequest != "undefined"){ // 非IE6浏览器 return new XMLHttpRequest(); }else if(typeof ActiveXObject != "undefined"){ // IE6浏览器 var version = [ "MSXML2.XMLHttp.6.0"

js输入密文弹出数字键盘

我们经常被产品要求,在移动端的web页面上的输入框输入密码时要弹出数字键盘,而不是全键盘,这个该怎么实现呢? 1.首先要弹出数字键盘,我们只能把input框的type从password改为tel 2.但经过第一步,输入的内容会变成明文,这时候也要星号显示,改怎么实现 经过一番研究,找到如下的实现方法: 1 function setPass(e) { 2 var target = e.currentTarget, 3 idx = target.selectionStart, 4 val = $(t

原生js写简单轮播图方式1-从左向右滑动

轮播图就是让图片每隔几秒自动滑动,达到图片轮流播放的效果.轮播图从效果来说有滑动式的也有渐入式的,滑动式的轮播图就是图片从左向右滑入的效果,渐入式的轮播图就是图片根据透明度渐渐显示的效果,这里说的是实现第一种效果的方法. 原理 相同大小的图片并成一列,但只显示其中一张图片,其余的隐藏,通过修改left值来改变显示的图片.点击查看效果 html部分 nav为总容器,第一个ul列表#index为小圆点列表,鼠标覆盖哪个小圆点就显现第几张图片,on是一个给小圆点添加背景颜色属性的类:第二个ul列表#i