`
ariyue
  • 浏览: 345217 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

javascript 键盘事件大全(兼容性研究)

阅读更多
转载  javascript 键盘事件大全(兼容性研究) 收藏

本文转自:http://www.cnblogs.com/rubylouvre/archive/2009/08/20/1550526.html

在进入正题前,我们看一下浏览器对于键盘的一些默认事件,这有助于我们用javascript截获键盘事件。

在form中, submit的快捷键是 enter,reset的快捷键是 esc。不过在IE6,safari4,ff3.5,opera10,chrome中 ,按Enter,不但激发form的submit事件,同时也会激发提交按钮的onclick,激发顺序为提交按钮的 onclick → form 的 onsubmit。
<html dir="ltr" lang="zh-CN"> <head> <meta charset="utf-8"/> <meta http-equiv="X-UA-Compatible" content="IE=Edge"> <title>键盘事件</title> </head> <body> <h3>键盘事件</h3> <form onsubmit="alert('Form is submiting');return false;"> <p><input type="text" value="将焦点聚焦于文本域中,然后按回车键或Esc键" /></p> <p><input type="submit" onclick="alert('submit button is clicked');" value="submit"/> <input type="reset" onclick="alert('reset button is clicked');" value="reset" /> </p> </form> </body> </html>

运行代码

不过并不止提交按钮会激发form的submit事件,连同上面的归纳如下:

   1. 如果表单里有一个type="submit"的按钮,回车键生效。
   2. 如果表单里只有一个type="text"的input,不管按钮是什么type,回车键生效。
   3. 如果按钮不是用input,而是用button,并且没有加type,IE下默认为type=button,FX默认为type=submit。
   4. 其他表单元素如textarea、select不影响,radio checkbox不影响触发规则,但本身在FX下会响应回车键,在IE下不响应。
   5. type="image"的input,效果等同于type="submit"。不知道为什么会设计这样一种type,不推荐使用,应该用CSS添加背景图合适些。

除了在按钮中绑定键盘事件外,浏览器还有一个accesskey 属性来指定链接的快捷键。注意 accesskey 的设置如果和浏览器的菜单相同,会优先于菜单。在IE中,快捷键是 alt + 设置的键值,FF是Alt+Shift+ 设置的键值。 在IE 中,a元素的 accesskey 只是使焦点转移到链接上,并不等同于点击,FF 中则相当于点击。与他对比的是,input type=checkbox 的 accesskey 效果不论在IE 还是 FF 中都是点击。另外,我们还可以配合label标签来加强语义,个人是十分推荐这种做法的。

剩下的就需要编程了。javascript事件主要通过以下三个事件来捕获键盘事件:onkeydown,onkeypress与onkeyup。该三个事件的执行顺序如下:onkeydown -> onkeypress ->onkeyup。在一般情况下,采用三种键盘事件均可对键盘输入进行有效的响应。当在实际使用中,会发现这几者有些不同的差别。

onkeypress事件不能对系统功能键(例如:后退、删除等,其中对中文输入法不能有效响应)进行正常的响应,onkeydown和onkeyup均可以对系统功能键进行有效的拦截,但事件截获的位置不同,可以根据具体的情况选择不同的键盘事件。

由于onkeypress不能对系统功能键进行捕获,导致window.event对象的keyCode属性和onkeydown,onkeyup 键盘事件中获取的keyCode属性不同,主要表现在onkeypress事件的keyCode对字母的大小写敏感,而onkeydown、 onkeyup事件不敏感;onkeypress事件的keyCode无法区分主键盘上的数字键和副键盘数字键的,而onkeydown、onkeyup 的keyCode对主副键盘的数字键敏感。
<!doctype html> <html dir="ltr" lang="zh-CN"> <head> <meta charset="utf-8"/> <meta http-equiv="X-UA-Compatible" content="IE=Edge"> <title>键盘事件</title> <style type="text/css"> td { text-align:center; } </style> <script type="text/javascript"> window.onload=function(){ document.onkeydown = showKeyDown document.onkeyup = showKeyUp document.onkeypress = showKeyPress } function showKeyDown(evt) { evt = (evt) ? evt : window.event document.getElementById("pressKeyCode").innerHTML = 0 document.getElementById("upKeyCode").innerHTML = 0 document.getElementById("pressCharCode").innerHTML = 0 document.getElementById("upCharCode").innerHTML = 0 restoreModifiers("") restoreModifiers("Down") restoreModifiers("Up") document.getElementById("downKeyCode").innerHTML = evt.keyCode if (evt.charCode) { document.getElementById("downCharCode").innerHTML = evt.charCode } showModifiers("Down", evt) } function showKeyUp(evt) { evt = (evt) ? evt : window.event document.getElementById("upKeyCode").innerHTML = evt.keyCode if (evt.charCode) { document.getElementById("upCharCode").innerHTML = evt.charCode } showModifiers("Up", evt) return false } function showKeyPress(evt) { evt = (evt) ? evt : window.event document.getElementById("pressKeyCode").innerHTML = evt.keyCode if (evt.charCode) { document.getElementById("pressCharCode").innerHTML = evt.charCode } showModifiers("", evt) return false } function showModifiers(ext, evt) { restoreModifiers(ext) if (evt.shiftKey) { document.getElementById("shift" + ext).style.backgroundColor = "#ff0000" } if (evt.ctrlKey) { document.getElementById("ctrl" + ext).style.backgroundColor = "#00ff00" } if (evt.altKey) { document.getElementById("alt" + ext).style.backgroundColor = "#0000ff" } } function restoreModifiers(ext) { document.getElementById("shift" + ext).style.backgroundColor = "#ffffff" document.getElementById("ctrl" + ext).style.backgroundColor = "#ffffff" document.getElementById("alt" + ext).style.backgroundColor = "#ffffff" } </script> </head> <body> <h3>键盘事件</h3> <form> <table border=1 cellpadding="2" cellspacing="0"> <tr> <th></th> <th>onKeyDown</th> <th>onKeyPress</th> <th>onKeyUp</th> </tr> <tr> <th>Key Codes</th> <td id="downKeyCode">0</td> <td id="pressKeyCode">0</td> <td id="upKeyCode">0</td> </tr> <tr> <th>Char Codes (IE5/Mac; NN6)</th> <td id="downCharCode">0</td> <td id="pressCharCode">0</td> <td id="upCharCode">0</td> </tr> <tr> <th rowspan="3">Modifier Keys</th> <td><span id="shiftdown">Shift</span></td> <td><span id="shift">Shift</span></td> <td><span id="shiftUp">Shift</span></td> </tr> <tr> <td><span id="ctrlDown">Ctrl</span></td> <td><span id="ctrl">Ctrl</span></td> <td><span id="ctrlUp">Ctrl</span></td> </tr> <tr> <td><span id="altdown">Alt</span></td> <td><span id="alt">Alt</span></td> <td><span id="altUp">Alt</span></td> </tr> </table> </form> </body> </html>

运行代码

我们可以利用以下脚本来监听网页中的键盘事件,一旦用户按下Enter键便开始你绑定的事件。
01. function getKey(e){
02.      e = e || window.event;
03.      var keycode = e.which ? e.which : e.keyCode;
04.      if (keycode == 13 || keycode == 108){ //如果按下ENTER键
05.         //在这里设置你想绑定的事件
06.      }
07. }
08. 
09. // 把keyup事件绑定到document中
10. function listenKey (  ) {
11.      if (document.addEventListener) {
12.          document.addEventListener( "keyup" ,getKey, false );
13.      } else if (document.attachEvent) {
14.          document.attachEvent( "onkeyup" ,getKey);
15.      } else {
16.          document.onkeyup = getKey;
17.      }
18. }

最后附上,键盘中所有按钮的keycode一览
字母和数字键的键码值(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
数字键盘上的键的键码值(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      
控制键键码值(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 A
分享到:
评论

相关推荐

    JavaScript 操作键盘的Enter事件(键盘任何事件),兼容多浏览器.docx

    在实现 JavaScript 操作键盘的 Enter 事件时,需要考虑多浏览器的兼容性问题。不同的浏览器对键盘事件的处理方式不同,例如,IE 浏览器使用 window.event 对象,而 Mozilla 浏览器使用 event 对象。 为解决这个问题...

    javascript键盘事件管理工具

    这篇名为“javascript键盘事件管理工具”的博文可能探讨了一种结构化和可扩展的方式来管理和处理键盘事件。这样的工具通常会提供一个中心化的注册系统,允许开发者注册和管理不同的键盘事件和相应的回调函数。这样做...

    javascript键盘事件[定义].pdf

    总的来说,处理 JavaScript 键盘事件时,开发者需要关注事件类型、浏览器兼容性和如何适配不同的浏览器特性。正确理解和应用这些知识点,可以确保键盘事件在各种环境下正常工作,从而提高网页应用的用户体验。

    javascript键盘事件全面控制脚本代码.docx

    ### JavaScript键盘事件全面控制脚本知识点解析 #### 一、概述 在JavaScript中,通过键盘事件可以捕捉用户的键盘输入行为,这对于开发具有交互性的Web应用至关重要。本文将深入探讨如何利用JavaScript来全面控制...

    JavaScript事件机制详细研究

    JavaScript 事件机制详细研究 ...JavaScript 事件机制是非常复杂的,它需要了解事件机制的实现方式、原理和浏览器的兼容性问题。只有深入了解这些知识点,才能编写出高效、可靠的 JavaScript 代码。

    javascript实现软键盘输入,兼容多种浏览器,测试通过

    综上所述,这个项目通过JavaScript实现了跨浏览器的软键盘输入功能,对于理解和掌握前端交互、DOM操作、事件处理、兼容性问题解决等方面都有很好的实践意义。开发者可以根据自身项目需求,参考这个项目进行定制化...

    Javascript鼠标事件大全

    ### JavaScript鼠标事件详解 #### 一、概述 在前端开发中,JavaScript的鼠标事件是非常重要的交互方式之一。这些事件能够帮助开发者捕捉用户的鼠标操作,并据此作出相应的反馈或处理逻辑。本文将详细介绍各种...

    javascript 按键事件(兼容各浏览器)

    在本文中,我们首先介绍了JavaScript中处理...兼容不同浏览器的JavaScript代码编写是一个需要细致考虑兼容性的过程,开发者需要对不同浏览器的事件处理和DOM属性有所了解,以确保功能的正常实现和用户体验的一致性。

    键盘 keycode的值 javascript时触发事件

    ### 键盘Keycode值与JavaScript触发事件 在前端开发中,经常需要处理用户的键盘输入事件,例如表单验证、...同时,随着Web技术的发展,使用更现代化的API如`event.key`和`event.code`可以提供更好的兼容性和用户体验。

    用javascript实现软键盘

    在实际应用中,我们还需要考虑性能优化,如避免过多的DOM操作,合理使用事件委托,以及考虑到浏览器兼容性问题。同时,为了提高用户体验,可以添加自定义主题、自动完成、预测输入等功能。 总结来说,用JavaScript...

    javascript 按键事件(兼容各浏览器).docx

    综上所述,处理JavaScript中的按键事件需要考虑到不同浏览器间的差异,并采取相应的兼容性策略。通过上述方法和技术,开发者可以有效地实现按键事件的监听和处理,从而为用户提供一致且流畅的交互体验。

    js键盘事件参考学习_兼容FireFox和IE

    【JavaScript 键盘事件详解与兼容性处理】 在JavaScript中,键盘事件是我们处理用户通过键盘输入的重要手段。本文将深入探讨浏览器的键盘事件、兼容性问题以及如何在Firefox和IE中实现代码,最后进行总结。 **第一...

    Javascript软键盘

    JavaScript软键盘是一种基于Web的虚拟输入工具,常用于网页表单填写,特别是在处理敏感信息如密码、信用卡号等时,为了提高安全性而替代系统默认的物理键盘。在本文中,我们将深入探讨JavaScript软键盘的工作原理、...

    一个javascript模拟的 虚拟键盘,效果非常棒!

    6. **兼容性**:确保虚拟键盘在主流浏览器和操作系统上都能正常工作。 7. **可扩展性**:方便添加新功能,如自定义快捷键、语言切换等。 总的来说,这个JavaScript虚拟键盘项目提供了一个高效、美观的解决方案,...

    JavaScript键盘事件常见用法实例分析

    开发者在使用键盘事件时需要注意区分各种键盘按键,并且需要考虑到不同浏览器对键盘事件的支持情况,可能需要做兼容性处理。例如,不同的浏览器可能会使用不同的内部机制来处理键盘事件,这可能会影响到事件对象中的...

    javascript 屏幕软键盘

    5. **跨平台兼容性**:由于不同的浏览器和设备可能存在差异,所以要确保虚拟键盘在各种环境下的兼容性。这可能涉及到对不同触摸事件的支持,以及对CSS前缀的处理。 6. **安全考虑**:在设计虚拟键盘时,应考虑安全...

    Javascript鼠标事件汇总

    - 不同浏览器可能对某些事件的支持程度不同,因此在开发时应考虑浏览器兼容性问题。 - 使用事件监听器(如`addEventListener`)可以更好地控制事件绑定,避免内存泄漏等问题。 - 对于复杂的交互逻辑,建议采用框架或...

    多款JS软键盘 及 常用JS兼容写法

    总的来说,JS软键盘的实现涉及了JavaScript基础、DOM操作、事件处理、CSS样式和浏览器兼容性等多个方面。通过深入理解这些技术并结合具体应用场景,我们可以创建出满足各种需求的JS软键盘,提供流畅且安全的在线输入...

Global site tag (gtag.js) - Google Analytics