JS实现自定义简单网页软键盘效果代码
作者:bea
本文实例讲述了JS实现自定义简单网页软键盘效果。分享给大家供大家参考,具体如下: 这是一款自定义的简单点的网页软键盘,没有使用任何控件,仅是为了练习JavaScript编写水平,安全性方面没有过多考虑,有顾虑的可以不用,目的是学习,希望对您有用处。 运行效果截图如下: 在线演示地址如下: http://demo./js/2015/js-simple-web-keybord-style-codes/ 具体代码如下: <!DOCTYPE html PUBLIC "-/
本文实例讲述了JS实现自定义简单网页软键盘效果。分享给大家供大家参考,具体如下:
这是一款自定义的简单点的网页软键盘,没有使用任何控件,仅是为了练习JavaScript编写水平,安全性方面没有过多考虑,有顾虑的可以不用,目的是学习,希望对您有用处。
运行效果截图如下:
在线演示地址如下:
http://demo./js/2015/js-simple-web-keybord-style-codes/
具体代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>自写一个简单点的网页软键盘</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<style>
* {
padding:0;
margin:0;
}
body {
background:#fff;
}
th, td {
border:1px solid #ccc;
padding:2px 0;
text-align:center;
}
td {
cursor:pointer
}
div {
border:1px solid #999;
float:left;
padding:1px;
display:none;
}
.num {
color:blue;
}
</style>
<script>
var htmlCode = {
"&" : "&",
'"' : """,
"<" : "<",
">" : ">",
}
function test(){
var input = document.getElementById("input");
var e = window.event || test.caller.arguments[0];
var el = e.target || e.srcElement;
if(el.tagName.toLowerCase() == "td" && el.rowSpan <= 1 && el.colSpan <= 1 ){
var str = el.innerHTML;
str = htmlCode[str] || str;
input.value += str;
}
if(el.innerHTML == "退格"){
input.value = input.value.slice(0,-1);
}
if(el.innerHTML == "切换大/小写"){
var els = document.getElementsByTagName("td");
for(var i = 0, l = els.length; i < l; i++){
var str = els[i].innerHTML;
if(/^[a-z]$/.test(str))
els[i].innerHTML = str.toUpperCase();
if(/^[A-Z]$/.test(str))
els[i].innerHTML = str.toLowerCase();
}
}
if(el.innerHTML == "ENTER"){
ctrKeyboard();
}
}
function ctrKeyboard(){
var el = document.getElementById("keyboard");
if(el.offsetWidth > 0)
el.style.display = "none";
else {
el.style.display = "block";
sortNum();
capsInit();
}
}
function capsInit(){
var els = document.getElementsByTagName("td");
for(var i = 0,j = 0, l = els.length; i < l; i++){
var str = els[i].innerHTML;
if(/^[A-Z]$/.test(str))
els[i].innerHTML = str.toLowerCase();
}
}
function sortNum (){
var arr = [0,1,2,3,4,5,6,7,8,9].sort(function(){
return Math.random() > 0.5?1:-1;
});
var els = document.getElementsByTagName("td");
for(var i = 0,j = 0, l = els.length; i < l; i++){
var str = els[i].innerHTML;
if(/^d$/.test(str))
els[i].innerHTML = arr[j++];
}
}
</script>
</head>
<body>
<input id="input" readonly="readonly"/><input type="button" value="打开/关闭 键盘" onclick="ctrKeyboard()"/>
<br>
<br>
<div id="keyboard">
<table cellspacing="1" width="480" onclick="test()">
<tr>
<th colspan="16">键盘模拟输入密码器</th>
</tr>
<tr>
<td>~</td>
<td>!</td>
<td>@</td>
<td>#</td>
<td>$</td>
<td>%</td>
<td>^</td>
<td>&</td>
<td>*</td>
<td>(</td>
<td>)</td>
<td>_</td>
<td>+</td>
<td>|</td>
<td rowspan="2" width="120">退格</td>
</tr>
<tr>
<td>`</td>
<td class="num">1</td>
<td class="num">2</td>
<td class="num">3</td>
<td class="num">4</td>
<td class="num">5</td>
<td class="num">6</td>
<td class="num">7</td>
<td class="num">8</td>
<td class="num">9</td>
<td class="num">0</td>
<td>-</td>
<td>=</td>
<td></td>
</tr>
<tr>
<td>q</td>
<td>w</td>
<td>e</td>
<td>r</td>
<td>t</td>
<td>y</td>
<td>u</td>
<td>i</td>
<td>o</td>
<td>p</td>
<td>{</td>
<td>}</td>
<td>[</td>
<td>]</td>
<td colspan="2">切换大/小写</td>
</tr>
<tr>
<td>a</td>
<td>s</td>
<td>d</td>
<td>f</td>
<td>g</td>
<td>h</td>
<td>j</td>
<td>k</td>
<td>l</td>
<td>:</td>
<td>"</td>
<td>;</td>
<td>'</td>
<td colspan="3" rowspan="3">ENTER</td>
</tr>
<tr>
<td>z</td>
<td>x</td>
<td>c</td>
<td>v</td>
<td>b</td>
<td>n</td>
<td>m</td>
<td><</td>
<td>></td>
<td>?</td>
<td>,</td>
<td>.</td>
<td>/</td>
</tr>
</table>
</div>
</body>
</html>
希望本文所述对大家JavaScript程序设计有所帮助。
有用 | 无用
这是一款自定义的简单点的网页软键盘,没有使用任何控件,仅是为了练习JavaScript编写水平,安全性方面没有过多考虑,有顾虑的可以不用,目的是学习,希望对您有用处。
运行效果截图如下:
在线演示地址如下:
http://demo./js/2015/js-simple-web-keybord-style-codes/
具体代码如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>自写一个简单点的网页软键盘</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<style>
* {
padding:0;
margin:0;
}
body {
background:#fff;
}
th, td {
border:1px solid #ccc;
padding:2px 0;
text-align:center;
}
td {
cursor:pointer
}
div {
border:1px solid #999;
float:left;
padding:1px;
display:none;
}
.num {
color:blue;
}
</style>
<script>
var htmlCode = {
"&" : "&",
'"' : """,
"<" : "<",
">" : ">",
}
function test(){
var input = document.getElementById("input");
var e = window.event || test.caller.arguments[0];
var el = e.target || e.srcElement;
if(el.tagName.toLowerCase() == "td" && el.rowSpan <= 1 && el.colSpan <= 1 ){
var str = el.innerHTML;
str = htmlCode[str] || str;
input.value += str;
}
if(el.innerHTML == "退格"){
input.value = input.value.slice(0,-1);
}
if(el.innerHTML == "切换大/小写"){
var els = document.getElementsByTagName("td");
for(var i = 0, l = els.length; i < l; i++){
var str = els[i].innerHTML;
if(/^[a-z]$/.test(str))
els[i].innerHTML = str.toUpperCase();
if(/^[A-Z]$/.test(str))
els[i].innerHTML = str.toLowerCase();
}
}
if(el.innerHTML == "ENTER"){
ctrKeyboard();
}
}
function ctrKeyboard(){
var el = document.getElementById("keyboard");
if(el.offsetWidth > 0)
el.style.display = "none";
else {
el.style.display = "block";
sortNum();
capsInit();
}
}
function capsInit(){
var els = document.getElementsByTagName("td");
for(var i = 0,j = 0, l = els.length; i < l; i++){
var str = els[i].innerHTML;
if(/^[A-Z]$/.test(str))
els[i].innerHTML = str.toLowerCase();
}
}
function sortNum (){
var arr = [0,1,2,3,4,5,6,7,8,9].sort(function(){
return Math.random() > 0.5?1:-1;
});
var els = document.getElementsByTagName("td");
for(var i = 0,j = 0, l = els.length; i < l; i++){
var str = els[i].innerHTML;
if(/^d$/.test(str))
els[i].innerHTML = arr[j++];
}
}
</script>
</head>
<body>
<input id="input" readonly="readonly"/><input type="button" value="打开/关闭 键盘" onclick="ctrKeyboard()"/>
<br>
<br>
<div id="keyboard">
<table cellspacing="1" width="480" onclick="test()">
<tr>
<th colspan="16">键盘模拟输入密码器</th>
</tr>
<tr>
<td>~</td>
<td>!</td>
<td>@</td>
<td>#</td>
<td>$</td>
<td>%</td>
<td>^</td>
<td>&</td>
<td>*</td>
<td>(</td>
<td>)</td>
<td>_</td>
<td>+</td>
<td>|</td>
<td rowspan="2" width="120">退格</td>
</tr>
<tr>
<td>`</td>
<td class="num">1</td>
<td class="num">2</td>
<td class="num">3</td>
<td class="num">4</td>
<td class="num">5</td>
<td class="num">6</td>
<td class="num">7</td>
<td class="num">8</td>
<td class="num">9</td>
<td class="num">0</td>
<td>-</td>
<td>=</td>
<td></td>
</tr>
<tr>
<td>q</td>
<td>w</td>
<td>e</td>
<td>r</td>
<td>t</td>
<td>y</td>
<td>u</td>
<td>i</td>
<td>o</td>
<td>p</td>
<td>{</td>
<td>}</td>
<td>[</td>
<td>]</td>
<td colspan="2">切换大/小写</td>
</tr>
<tr>
<td>a</td>
<td>s</td>
<td>d</td>
<td>f</td>
<td>g</td>
<td>h</td>
<td>j</td>
<td>k</td>
<td>l</td>
<td>:</td>
<td>"</td>
<td>;</td>
<td>'</td>
<td colspan="3" rowspan="3">ENTER</td>
</tr>
<tr>
<td>z</td>
<td>x</td>
<td>c</td>
<td>v</td>
<td>b</td>
<td>n</td>
<td>m</td>
<td><</td>
<td>></td>
<td>?</td>
<td>,</td>
<td>.</td>
<td>/</td>
</tr>
</table>
</div>
</body>
</html>
希望本文所述对大家JavaScript程序设计有所帮助。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- JavaScript实现带缓冲效果的随屏滚动漂浮广告代码
- jQuery实现可关闭固定于底(顶)部的工具条菜单效果
- JS实现的自定义网页拖动类
- js基础知识(公有方法、私有方法、特权方法)
- JS实现的N多简单无缝滚动代码(包含图文效果)
- javascript中的altKey 和 Event属性大全
- JS日期加减,日期运算代码
- 程序员必知35个jQuery 代码片段
- js如何实现淡入淡出效果
- JavaScript数组去重的五种方法
- javascript实现tab切换的两个实例
- Javascript中的return作用及javascript return关键字用法详解
- js实现选中页面文字将其分享到新浪微博
- 使用JQuery实现的分页插件分享
- javascript实现tab切换的四种方法
- JavaScript精炼之构造函数 Constructor及Constructor属性详解
- JS使用正则表达式除去字符串中重复字符的方法
- JS使用cookie实现DIV提示框只显示一次的方法
- JS实现的新浪微博大厅文字内容滚动效果代码