千家信息网

JS键盘事件对象之keyCode、charCode、which属性对比

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,先说一些有关键盘事件的事项:用js实现键盘记录,要关注浏览器的三种按键事件类型,即keydown,keypress和keyup,它们分别对应onkeydown、 onkeypress和onkeyup这
千家信息网最后更新 2025年01月20日JS键盘事件对象之keyCode、charCode、which属性对比

先说一些有关键盘事件的事项:用js实现键盘记录,要关注浏览器的三种按键事件类型,即keydown,keypress和keyup,它们分别对应onkeydown、 onkeypress和onkeyup这三个事件句柄。一个典型的按键会产生所有这三种事件,依次是keydown,keypress,然后是按键释放时候的keyup。

  在这3种事件类型中,keydown和keyup比较底层,而keypress比较高级。这里所谓的高级是指,当用户按下shift + 1时,keypress是对这个按键事件进行解析后返回一个可打印的"!"字符,而keydown和keyup只是记录了shift + 1这个事件。[1]

  但是keypress只能针对一些可以打印出来的字符有效,而对于功能按键,如F1-F12、Backspace、Enter、Escape、 PageUP、PageDown和箭头方向等,就不会产生keypress事件,但是可以产生keydown和keyup事件。然而在FireFox中,功能按键是可以产生keypress事件的。

  传递给keydown、keypress和keyup事件句柄的事件对象有一些通用的属性。如果Alt、Ctrl或Shift和一个按键一起按下,这通过事件的altKey、ctrlKey和shiftKey属性表示,这些属性在FireFox和IE中是通用的,返回值为布尔值。还有一个metaKey属性,但IE表示不支持。

  

  既然是比较三者的异同,第一件事肯定就是去了解它们的定义:

keyCode 属性返回onpress事件触发的键的值的字符代码,或者 onkeydown 或 onkeyup 事件的键的代码。

两种代码类型的区别是:

  • 字符代码 - 表示 ASCII 字符的数字

  • 键盘代码 - 表示键盘上真实键的数字

charCode 属性返回onpress事件触发键值的字母代码,仅用于字符代码。

which属性和keyCode类似,但是不兼容IE8以下的浏览器。

  下面再来说说让人头疼的浏览器问题:兼容性!

1、在不同浏览器下如何转化为字符

  (1)FireFox、Opera、Chrome

事件对应的函数有一个隐藏的变量e,表示发生事件。

e有一个属性e.which指示哪个键被按下,给出该键的索引值(按键码)。

静态函数String.fromCharCode()可以把索引值(按键码)转化成该键对应的的字符。

eg:

1   2 

FireFox、Opera、Chrome输入"a";

输出: "按键码:97 字符:a"

  (2) IE

IE不需要e变量,window.event表示发生事件。

window.event有一个属性window.event.keyCode指示哪个键被按下,给出该键的索引值(按键码)。

静态函数String.fromCharCode()可以把索引值(按键码)转化成该键对应的的字符。

eg:

1   2 

IE中输入:a

输出:按键码:97 字符:a

2、如何判断浏览器类型

利用navigator对象的appName属性。

IE:navigator.appName=="Microsoft Internet Explorer"

FireFox、Opera、Chrome:navigator.appName=="Netscape"

eg:

    

IE、FireFox、Opera、Chrome中输入:a

输出:按键码:97 字符:a

  由于当前浏览器没有相应属性的话会返回undefined,因此,利用||运算符简化如下:

1   2 

  注意IE只有keyCode属性,FireFox中有which和charCode属性,Opera中有keyCode和which属性,Chrome中有keyCode、which和charCode属性IE8 及其更早版本不支持 which 属性。"DOM3级"提出的key属性虽好,由于兼容性问题,所以不建议用!

  

  总结:在keydown事件里面,事件包括了keyCode - 用户按下的键的物理编码。在keypress里,keyCode包含了字符编码,即表示字符的ASCII编码。这样的形式适用于所以浏览器,除了火狐,它在keypress事件中的keyCode返回值为0;如果你想获取用户实际敲击的按钮,用keydown事件来获取事件对象,并获取keycode值,这在所有浏览器都行的通。另一方面,如果你想获取用户输入的字符,那么就使用keypress来获取,然后获取charCode【火狐或Safari】或keyCode【其他浏览器】。

  

  附:keyPress和keyDown、keyUp之间的差别:

1、keyPress首要用来捕获可打印的字符。比如数字(重视:包含Shift+数字的符号)、字母(重视:包含大小写)、小键盘等除了F1-F12、SHIFT、Alt、Ctrl、Insert、Home、PgUp、Delete、End、PgDn、ScrollLock、Pause、NumLock...

2、keyPress只能捕获单个字符,keyDown和keyUp可以捕获组合键。

3、keyPress可以捕获单个字符的大小写。

4、keyDown和keyUp对于单个字符捕获的keyValue都是一个值,也就是不区分单个字符的大小写。

5、keyPress不区分小键盘和主键盘的数字字符。keyDown和keyUp区分小键盘和主键盘的数字字符。

6、此中PrScrn按键keyPress、keyDown和keyUp都不能捕获。

  


字符 事件 按键 属性 浏览器 浏览 代码 键盘 数字 单个 用户 类型 索引 输入 对象 函数 大小 小键盘 编码 小键 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 上海农行软件开发部岗位职责 湖南最快的服务器虚拟主机 软件开发 外快 网吧没有网络安全许可证怎么处理 网络技术部月工作计划 关于召开网络技术交流会的通知 数据库更新查询的三要素 莆田市天地人网络技术有限公司 幻塔星岛服务器怎么没了 山西曙光服务器虚拟化定制云主机 思科网络技术学院教材封面 淘宝开源数据库 优选互联网科技电话如何下载 昭通服务器租用公司 odps平台是什么数据库 vr直播软件开发 美国亚马逊服务器 台州溺水网络安全教育直播 计算机网络技术基础看什么书 银行软件开发公司有哪些 魔兽世界数据库取消了 上海农行软件开发部岗位职责 安徽机架式服务器虚拟主机 深圳三国网络技术有限公司 周村轻工业软件开发 腾讯软件开发人是谁 广州清能互联网科技 按照网络安全等级保护制度 锐点数据库 济南京座网络技术有限公司
0