代码来源忘记是哪个大神的了,抱歉抱歉

放上源码:

<!-- 虚拟键盘 -->
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" >
<title>虚拟键盘</title>
<style>
#inputArea{position: absolute; top: 30%; left: 20%;}
.keyboardBox{position: fixed; top: 50%; left: 20%; width: 708px; height: 256px; margin: 0; padding: 10px; background-color: #ccc; font-size: 16px;}
.line{position: relative; height: 50px; line-height: 50px;}
.keys, .keysCmd, .keys_d{box-sizing: border-box; float: left; width: 45px; height: 45px; line-height: 45px; margin: 0 0 3px 3px; border-radius: 4px; border: 1px solid #333; text-align: center; cursor: pointer; background-color: #fff;}
.keys:hover, .keysCmd:hover, .keys_d:hover{box-shadow: 0px 0px 3px #333 inset;}
.keys:active, .keysCmd:active, .keys_d:active{background-color: #dedede;}
.active{background-color: #dedede; box-shadow: 0px 0px 3px #333 inset;}
.keys_d{height: 45px; line-height: 20px;}
.key_enter{width: 102px;}
.k-w-50{width: 50px;}
.k-w-70{width: 70px;}
.k-w-75{width: 75px;}
.k-w-80{width: 80px;}
.k-w-100{width: 100px;}
.k-w-120{width: 120px;}
.k-w-704{width: 704px;}
.gap{margin-left: 30px;}
.gap_t{margin-top: 10px;}
.line .l-h-40{line-height: 40px;}
.f-s-14{font-size: 14px;}
.t-a-l{padding-left: 15px; text-align: left;}
</style>
</head>
<body>
<textarea name="inputArea" id="inputArea" cols="80" rows="10" placeholder="点击虚拟键盘输入"></textarea> <div class="keyboardBox" id="keyboard">
<div class="line gap_t">
<div class="keys_d t-a-l" data-kid="192"><div>~</div><div>`</div></div>
<div class="keys_d t-a-l" data-kid="49"><div>!</div><div>1</div></div>
<div class="keys_d t-a-l" data-kid="50"><div>@</div><div>2</div></div>
<div class="keys_d t-a-l" data-kid="51"><div>#</div><div>3</div></div>
<div class="keys_d t-a-l" data-kid="52"><div>$</div><div>4</div></div>
<div class="keys_d t-a-l" data-kid="53"><div>%</div><div>5</div></div>
<div class="keys_d t-a-l" data-kid="54"><div>^</div><div>6</div></div>
<div class="keys_d t-a-l" data-kid="55"><div>&amp;</div><div>7</div></div>
<div class="keys_d t-a-l" data-kid="56"><div>*</div><div>8</div></div>
<div class="keys_d t-a-l" data-kid="57"><div>(</div><div>9</div></div>
<div class="keys_d t-a-l" data-kid="48"><div>)</div><div>0</div></div>
<div class="keys_d t-a-l" data-kid="189"><div>_</div><div>-</div></div>
<div class="keys_d t-a-l" data-kid="187"><div>+</div><div>=</div></div>
<div class="keysCmd k-w-80 l-h-40 f-s-14" data-kid="8">Backspace</div>
</div>
<div class="line">
<div class="keysCmd k-w-50" data-kid="9">Tab</div>
<div class="keys" data-kid="81">Q</div>
<div class="keys" data-kid="87">W</div>
<div class="keys" data-kid="69">E</div>
<div class="keys" data-kid="82">R</div>
<div class="keys" data-kid="84">T</div>
<div class="keys" data-kid="89">Y</div>
<div class="keys" data-kid="85">U</div>
<div class="keys" data-kid="73">I</div>
<div class="keys" data-kid="79">O</div>
<div class="keys" data-kid="80">P</div>
<div class="keys_d t-a-l" data-kid="219"><div>{</div><div>[</div></div>
<div class="keys_d t-a-l" data-kid="221"><div>}</div><div>]</div></div>
<div class="keys_d k-w-75 t-a-l" data-kid="220"><div>|</div><div>\</div></div>
</div>
<div class="line">
<div class="keysCmd k-w-70 f-s-14" data-kid="20">CapsLock</div>
<div class="keys" data-kid="65">A</div>
<div class="keys" data-kid="83">S</div>
<div class="keys" data-kid="68">D</div>
<div class="keys" data-kid="70">F</div>
<div class="keys" data-kid="71">G</div>
<div class="keys" data-kid="72">H</div>
<div class="keys" data-kid="74">J</div>
<div class="keys" data-kid="75">K</div>
<div class="keys" data-kid="76">L</div>
<div class="keys_d t-a-l" data-kid="186"><div>:</div><div>;</div></div>
<div class="keys_d t-a-l" data-kid="222"><div>"</div><div>'</div></div>
<div class="keysCmd key_enter" data-kid="13">Enter</div>
</div>
<div class="line">
<div class="keysCmd k-w-100" data-kid="16">Shift</div>
<div class="keys" data-kid="90">Z</div>
<div class="keys" data-kid="88">X</div>
<div class="keys" data-kid="67">C</div>
<div class="keys" data-kid="86">V</div>
<div class="keys" data-kid="66">B</div>
<div class="keys" data-kid="78">N</div>
<div class="keys" data-kid="77">M</div>
<div class="keys_d t-a-l" data-kid="188"><div><</div><div>,</div></div>
<div class="keys_d t-a-l" data-kid="190"><div>></div><div>.</div></div>
<div class="keys_d t-a-l" data-kid="191"><div>?</div><div>/</div></div>
<div class="keysCmd k-w-120" data-kid="16">Shift</div>
</div>
<div class="line">
<div class="keys k-w-704" data-kid="32">&nbsp;</div>
</div>
</div>
<!-- <script type="text/javascript" src="keyboard.js"></script> -->
<script>
window.onload = function(){
new keyboard().addKeyboard('inputArea');
}
</script>
</body>
</html> <script type="text/javascript">
//* keyboard.js var keyboard = (function(){
var keyboardObj = document.getElementById('keyboard'), _inputID, _shiftStatus = false, _capsLock = false; // 显示虚拟键盘
var _showKeyboard = function(){
keyboardObj.style.display = 'block';
}
// 隐藏虚拟键盘
var _hideKeyboard = function(){
keyboardObj.style.display = 'none';
} // 获取输入框的内容
var _getInputContent = function(){
var inputContent = document.getElementById(_inputID).innerText || document.getElementById(_inputID).textContent;
return inputContent;
}
// 输入新内容
var _inputNewContent = function(str){
document.getElementById(_inputID).innerHTML = str;
} // 添加classname
function _addClass(obj, cls){
var obj_class = obj.className,
blank = obj_class != '' ? ' ' : '';
var added = obj_class + blank + cls;
obj.className = added; }
// 删除classname
function _removeClass(obj, cls){
var obj_class = ' ' + obj.className + ' ';
obj_class = obj_class.replace(/(\s+)/gi, ' ');
var removed = obj_class.replace(' ' + cls + ' ', ' ');
removed = removed.replace(/(^\s+)|(\s+$)/g, '');
obj.className = removed;
}
// 为按钮添加active
function _addActive(cls, keycode){
var keys = document.getElementsByClassName(cls);
for(var o of keys){
if(o.getAttribute('data-kid') == keycode){
_addClass(o, 'active');
}
}
}
// 为按钮取消active
function _removeActive(cls, keycode){
var keys = document.getElementsByClassName(cls);
for(var o of keys){
if(o.getAttribute('data-kid') == keycode){
_removeClass(o, 'active');
}
}
} // 添加shift状态
var _addShift = function(){
_addActive('keysCmd', 16);
return _shiftStatus = true;
}
// 取消shift状态
var _removeShift = function(){
_removeActive('keysCmd', 16);
return _shiftStatus = false;
} // 添加CapsLock状态
var _addCapsLock = function(){
_addActive('keysCmd', 20);
return _capsLock = true;
}
// 取消CapsLock状态
var _removeCapsLock = function(){
_removeActive('keysCmd', 20);
return _capsLock = false;
} // 给按钮绑定触发键盘事件的事件
var _bindEvent = function(){
// 字母按键
var keys = keyboardObj.getElementsByClassName('keys');
for(var o of keys){
o.onclick = function(){
var strArr = _getInputContent().split('');
if(_shiftStatus){
_capsLock = !_capsLock;
_capsLock ? strArr.push(this.innerHTML.toUpperCase()) : strArr.push(this.innerHTML.toLowerCase());
_capsLock = !_capsLock;
_removeShift();
}
else{_capsLock ? strArr.push(this.innerHTML.toUpperCase()) : strArr.push(this.innerHTML.toLowerCase());}
_inputNewContent(strArr.join(''));
}
}
// 数字及特殊符号按键
var keys_d = document.getElementsByClassName('keys_d');
for(var o of keys_d){
o.onclick = function(){
var strArr = _getInputContent().split('');
var key1 = this.getElementsByTagName('div')[0].innerHTML;
var key2 = this.getElementsByTagName('div')[1].innerHTML;
if(_shiftStatus){
strArr.push(key1);
_removeShift();
}else{strArr.push(key2);}
_inputNewContent(strArr.join(''));
}
} // shift、capslock、enter、tab、backspace 按钮
var keysCmd = document.getElementsByClassName('keysCmd');
for(var o of keysCmd){
o.onclick = function(){
var strArr = _getInputContent().split('');
var keyCode = this.getAttribute('data-kid');
if(keyCode == 8){
strArr.pop();
_inputNewContent(strArr.join(''));
}else if(keyCode == 9){
strArr.push('&nbsp;&nbsp;');
_inputNewContent(strArr.join(''));
}else if(keyCode == 13){
strArr.push('\n');
_inputNewContent(strArr.join(''));
}else if(keyCode == 16){
if(!_shiftStatus){_addShift();}else{_removeShift();}
}else if(keyCode == 20){
if(!_capsLock){_addCapsLock();}else{_removeCapsLock();}
}
}
}
} var keyboard = function(){} // 输入框绑定键盘
keyboard.prototype.addKeyboard = function(id){
_inputID = id
var inputObj = document.getElementById(id);
inputObj.onclick = _showKeyboard();
_bindEvent();
} return keyboard;
})()
</script>

html

放上效果图:

原生js和css写虚拟键盘的更多相关文章

  1. 告别组件之教你使用原生js和css写移动端轮播图

    在工作中由于项目需要要写一个轮播图,本想使用组件直接调用实现快速开发,但是一想到自己经常使用组件但是让自己手写的话确实一点都不会. 一个不会手写组件的前端程序员不是一个好程序员!于是打算自己手写一个. ...

  2. 原生JS、CSS实现的转盘效果(目前仅支持webkit)

    这是一个原生JS.CSS实现的转盘效果(题目在这:http://www.cnblogs.com/arfeizhang/p/turntable.html),花了半个小时左右,准备睡觉,所以先贴一段代码, ...

  3. 原生js判断css动画结束 css 动画结束的回调函数

    原文:原生js判断css动画结束 css 动画结束的回调函数 css3 的时代,css3--动画 一切皆有可能: 传统的js 可以通过回调函数判断动画是否结束:即使是采用CSS技术生成动画效果,Jav ...

  4. 原生js更改css样式的两种方式

    下面我给大家介绍的是原生js更改CSS样式的两种方式: 1通过在javascript代码中的node.style.cssText="css表达式1:css表达式2:css表达式3  &quo ...

  5. 【javascript】原生js更改css样式的两种方式

    下面我给大家介绍的是原生js更改CSS样式的两种方式: 1通过在javascript代码中的node.style.cssText="css表达式1:css表达式2:css表达式3  &quo ...

  6. 用原生JS读写CSS样式的方法总结

    为了日后方便查询,本人翻阅了一些资料总结了以下方法,仅限原生JS,如有不对的地方欢迎指出!只求大家看完觉得有学到点什么就OK了!   一.可以通过DOM节点对象的style对象(即CSSStyleDe ...

  7. jq商品展示图放大镜 and 原生js和html5写的放大镜效果 ~~效果不错

    <!DOCTYPE HTML><html lang="en-US"><head> <meta charset="UTF-8&qu ...

  8. 原生JS实战:写了个斗牛游戏,分享给大家一起玩!

    本文是苏福的原创文章,转载请注明出处:苏福CNblog:http://www.cnblogs.com/susufufu/p/5869953.html 该程序是本人的个人作品,写的不好,未经本人允许,请 ...

  9. 原生JS实战:写了个一边玩游戏,一边记JS的API的游戏

    本文是苏福的原创文章,转载请注明出处:苏福CNblog:http://www.cnblogs.com/susufufu/p/5878913.html 本程序[一边玩游戏,一边记JS的API]是本人的个 ...

随机推荐

  1. 发送http请求和https请求的工具类

    package com.haiyisoft.cAssistant.utils; import java.io.IOException;import java.util.ArrayList; impor ...

  2. 最简SpringBoot程序制法

    JDK:1.8.0_212 IDE:STS4(Spring Tool Suit4 Version: 4.3.2.RELEASE) 工程下载:https://files.cnblogs.com/file ...

  3. 转载:一文详解SQL解析与应用

    转载地址:http://www.elecfans.com/emb/20180618696111.html 数据库作为核心的基础组件,是需要重点保护的对象.任何一个线上的不慎操作,都有可能给数据库带来严 ...

  4. flask_sqlalchemy的session线程安全源码解读

    flask_sqlalchemy是如何在多线程中对数据库操作不相互影响 数据库操作隔离 结论:使用scoped_session实现数据库操作隔离 flask的api.route()接收一个请求,就会创 ...

  5. 六十四:CSRF攻击与防御之系统准备之病毒网站转账实现

    准备一个页面或图片,用于用户访问 一:表单方式 视图 from flask import Flask, render_template app = Flask(__name__) @app.route ...

  6. SqlServer:SqlServer(数据库备份,数据文件迁移,增加数据库文件组,递归查询一周报送情况,查询近X天未报送单位,截断数据库日志,复制单个或多个数据库表到另一个数据库 )

    1.数据备份 ) ) ) )),'-','') ) SET @savePath = 'f:/DatabaseBackup/' DECLARE My_Cursor CURSOR FOR ( select ...

  7. C# 线程thread

    一.问题总结 1. 在WinForm开发过程中用到线程时,往往需要在线程中访问线程外的控件,比如:设置textbox的Text值等等.如果直接访问UI控件会报出“从不是创建控件的线程访问它”错误.控件 ...

  8. 对于MVVM的理解

    MVVM 是Model-View-ViewModel的缩写. Model 代表数据模型,也可以在model中定义数据修改和操作的业务逻辑. View 代表UI组件,负责姜黄素局模型转化成UI展现出来. ...

  9. Redux之combineReducers(reducers)详解

    大家好,最近有点忙,忙什么呢?忙着学习一个新的框架Redux,那么这个框架主要是用来做什么的,这篇博客暂时不做介绍,这篇博客针对有一定Redux开发基础的人员,所以今天我讲的重点是Redux里面很重要 ...

  10. Android开发 调试环境

    我们这里有3种调试方法,Unity Remote,Android Studio和第三方模拟器 准备工作 (1)Android Studio:安装Google USB Driver (2)手机安装Uni ...