javascript键盘事件用法总结
}
<body>
}
5. type="image"的input,效果等同于type="submit"。不知道为什么会设计这样一种type,不推荐使用,应该用CSS添加背景图合适些。
</tr>
document.getElementById("pressKeyCode").innerHTML = evt.keyCode
text-align:center;
}
if(keycode == 13 || keycode == 108){ //如果按下ENTER键
</p>
例1:
<p><input type="text" value="将焦点聚焦于文本域中,然后按回车键或Esc键" /></p>
return false
<script type="text/javascript">
最后附上,键盘中所有按钮的keycode一览
document.getElementById("upKeyCode").innerHTML = 0
<td id="pressKeyCode">0</td>
document.onkeyup = showKeyUp
复制代码 代码示例:
document.getElementById("upKeyCode").innerHTML = evt.keyCode<meta http-equiv="X-UA-Compatible" content="IE=Edge">
}
控制键键码值(keyCode) 按键 键码 按键 键码 按键 键码 按键 键码 BackSpace 8 Esc 27 Right Arrow 39 -_ 189 Tab 9 Spacebar 32 Down Arrow 40 .> 190 Clear 12 Page Up 33 Insert 45 /? 191 Enter 13 Page Down 34 Delete 46 `~ 192 Shift 16 End 35 Num Lock 144 [{ 219 Control 17 Home 36 ;: 186 \| 220 Alt 18 Left Arrow 37 =+ 187 ]} 221 Cape Lock 20 Up Arrow 38 ,< 188 '" 222
<input type="reset" onclick="alert('reset button is clicked');" value="reset" />
</tr>
<h3>键盘事件</h3>
onkeypress事件不能对系统功能键(例如:后退、删除等,其中对中文输入法不能有效响应)进行正常的响应,onkeydown和onkeyup均可以对系统功能键进行有效的拦截,但事件截获的位置不同,可以根据具体的情况选择不同的键盘事件。
<th>onKeyUp</th>
return false
<tr>
字母和数字键的键码值(keyCode) 按键 键码 按键 键码 按键 键码 按键 键码 A 65 J 74 S 83 1 49 B 66 K 75 T 84 2 50 C 67 L 76 U 85 3 51 D 68 M 77 V 86 4 52 E 69 N 78 W 87 5 53 F 70 O 79 X 88 6 54 G 71 P 80 Y 89 7 55 H 72 Q 81 Z 90 8 56 I 73 R 82 0 48 9 57
<html dir="ltr" lang="zh-CN">
} else {
}
</script>
<td id="downCharCode">0</td>
function showKeyPress(evt) {
4. 其他表单元素如textarea、select不影响,radio checkbox不影响触发规则,但本身在FX下会响应回车键,在IE下不响应。
document.onkeydown = showKeyDown
<tr>
// 把keyup事件绑定到document中
if (document.addEventListener) {
<td><span id="shiftdown">Shift</span></td>
evt = (evt) ? evt : window.event
<td><span id="ctrlUp">Ctrl</span></td>
if (evt.charCode) {
<td><span id="ctrl">Ctrl</span></td>
}
window.onload=function(){
3. 如果按钮不是用input,而是用button,并且没有加type,IE下默认为type=button,FX默认为type=submit。
if (evt.charCode) {
<td id="upKeyCode">0</td>
}
</body>
另外,还可以用event.altKey,event.ctrlKey,event.metaKey(上有微软的旗帜),event.shiftKey来判断对应的键是否被按下,因为它们都是返回一个布尔值。
e = e || window.event;
<form>
<table border=1 cellpadding="2" cellspacing="0">
evt = (evt) ? evt : window.event
</tr>
showModifiers("Down", evt)
}
}
<!doctype html>
1. 如果表单里有一个type="submit"的按钮,回车键生效。
<head>
<th>onKeyDown</th>
<html dir="ltr" lang="zh-CN">
evt = (evt) ? evt : window.event
function showKeyDown(evt) {
不过并不止提交按钮会激发form的submit事件,连同上面的归纳如下:
</tr>
function restoreModifiers(ext) {
}
<tr>
}
}
复制代码 代码如下:
document.getElementById("downKeyCode").innerHTML = evt.keyCode<td><span id="altdown">Alt</span></td>
<td id="downKeyCode">0</td>
function showModifiers(ext, evt) {
<td><span id="shiftUp">Shift</span></td>
<th>onKeyPress</th>
在form中, submit的快捷键是 enter,reset的快捷键是 esc。不过在IE6,safari4,ff3.5,opera10,chrome中,按Enter,不但激发form的submit事件,同时也会激发提交按钮的onclick,激发顺序为提交按钮的 onclick → form 的 onsubmit。
document.getElementById("alt" + ext).style.backgroundColor = "#0000ff"
<td id="pressCharCode">0</td>
<th>Key Codes</th>
document.getElementById("downCharCode").innerHTML = evt.charCode
<td><span id="altUp">Alt</span></td>
<td><span id="alt">Alt</span></td>
} else if (document.attachEvent) {
document.getElementById("ctrl" + ext).style.backgroundColor = "#00ff00"
if (evt.charCode) {
<td id="upCharCode">0</td>
document.onkeyup = getKey;
2. 如果表单里只有一个type="text"的input,不管按钮是什么type,回车键生效。
var keycode = e.which ? e.which : e.keyCode;
restoreModifiers("")
<p><input type="submit" onclick="alert('submit button is clicked');" value="submit"/>
if (evt.altKey) {
</head>
document.getElementById("shift" + ext).style.backgroundColor = "#ff0000"
<td><span id="ctrlDown">Ctrl</span></td>
复制代码 代码示例:
<style type="text/css"></style>
<head>
除了在按钮中绑定键盘事件外,浏览器还有一个accesskey 属性来指定链接的快捷键。注意 accesskey 的设置如果和浏览器的菜单相同,会优先于菜单。在IE中,快捷键是 alt + 设置的键值,FF是Alt+Shift+ 设置的键值。 在IE 中,a元素的 accesskey 只是使焦点转移到链接上,并不等同于点击,FF 中则相当于点击。与他对比的是,input type=checkbox 的 accesskey 效果不论在IE 还是 FF 中都是点击。另外,我们还可以配合label标签来加强语义,个人是十分推荐这种做法的。
</form>
}
</tr>
<h3>键盘事件</h3>
document.getElementById("shift" + ext).style.backgroundColor = "#ffffff"
showModifiers("", evt)
}
}
<meta charset="gb2312"/>
<th rowspan="3">Modifier Keys</th>
function showKeyUp(evt) {
由于onkeypress不能对系统功能键进行捕获,导致window.event对象的keyCode属性和onkeydown,onkeyup 键盘事件中获取的keyCode属性不同,主要表现在onkeypress事件的keyCode对字母的大小写敏感,而onkeydown、 onkeyup事件不敏感;onkeypress事件的keyCode无法区分主键盘上的数字键和副键盘数字键的,而onkeydown、onkeyup 的keyCode对主副键盘的数字键敏感。
</head>
showModifiers("Up", evt)
<tr>
</table>
if (evt.shiftKey) {
}
document.getElementById("upCharCode").innerHTML = evt.charCode
document.getElementById("pressCharCode").innerHTML = evt.charCode
我们可以利用以下脚本来监听网页中的键盘事件,一旦用户按下Enter键便开始你绑定的事件。
剩下的就需要编程了。javascript事件主要通过以下三个事件来捕获键盘事件:onkeydown,onkeypress与onkeyup。该三个事件的执行顺序如下:onkeydown -> onkeypress ->onkeyup。在一般情况下,采用三种键盘事件均可对键盘输入进行有效的响应。当在实际使用中,会发现这几者有些不同的差别。
restoreModifiers("Down")
<tr>
</html>
document.getElementById("pressCharCode").innerHTML = 0
function listenKey ( ) {
restoreModifiers(ext)
<meta http-equiv="X-UA-Compatible" content="IE=Edge">
<title>键盘事件</title>
<th>Char Codes (IE5/Mac; NN6)</th>
<title>键盘事件</title>
document.getElementById("alt" + ext).style.backgroundColor = "#ffffff"
document.getElementById("pressKeyCode").innerHTML = 0
}
td {
<meta charset="gb2312"/>
//在这里设置你想绑定的事件
function getKey(e){
数字键盘上的键的键码值(keyCode)
功能键键码值(keyCode)
按键
键码
按键
键码
按键
键码
按键
键码
0
96
8
104
F1
112
F7
118
1
97
9
105
F2
113
F8
119
2
98
*
106
F3
114
F9
120
3
99
+
107
F4
115
F10
121
4
100
Enter
108
F5
116
F11
122
5
101
-
109
F6
117
F12
123
6
102
.
110
7
103
/
111
document.getElementById("ctrl" + ext).style.backgroundColor = "#ffffff"
</html>
<td><span id="shift">Shift</span></td>
<tr>
<th></th>
</body>
document.attachEvent("onkeyup",getKey);
document.addEventListener("keyup",getKey,false);
document.onkeypress = showKeyPress
</form>
<form onsubmit="alert('Form is submiting');return false;">
if (evt.ctrlKey) {
restoreModifiers("Up")
</tr>
相关热词:
本站内容来源于网络,如有侵权请与我们联系,我们会及时删除,我们深感抱歉!
注:本站所有信息仅供用于网络技术学习参考,学习中请遵循相关法律法规!
本文地址: https://v30.fanwenzhu.com/jq/jc/6951.shtml
相关文章
热门TAG
win10 ecshop 主机 阿里云 解决 配置 C# C++ 解析 SQL语句 命令 Go语言 方法 CSS3 HTML5 CSS win7 MSSQL 服务器配置 IIS7.5 IIS7 IIS6 IIS CentOS 7 Linux oracle数据库 oracle phpcms discuz discuz教程最新文章
-
PHP识别相片是否是颠倒的
时间:2020-12-28
-
python编程有哪些ide
时间:2020-12-28
-
python开发工程师是做什么
时间:2020-12-28
-
php构造函数的作用
时间:2020-12-28
-
php怎么跟数据库连接
时间:2020-12-28
-
php实现顺序线性表
时间:2020-12-28
-
Python多重继承中的菱形继
时间:2020-12-28
-
php中break的作用
时间:2020-12-28
热门文章
-
php中常用的正则表达式使用方法
时间:2020-12-25
-
asp与php区别是什么?
时间:2020-12-27
-
PHP识别相片是否是颠倒的,并且重新摆正
时间:2020-12-28
-
Yii授权之基于角色的存取控制 (RBAC)
时间:2020-12-23
-
php的一键安装包有哪些 php环境搭建
时间:2020-12-19
-
php实现对图片对称加解密(适用身份证加
时间:2020-12-25
-
php如何理解面向对象
时间:2020-12-28
-
超详细分析php docker的原理及作用
时间:2020-12-27
-
Python控制Excel实现自动化办公
时间:2020-12-23
-
session的作用是什么
时间:2020-12-25
