键盘事件keydown、keypress、keyup随笔整理总结

 

键盘事件keydown、keypress、keyup随笔整理总结

英文输入法:

事件触发顺序:keydown - > keypress - > keyup

中文输入法:

firfox:输入触发keydown,回车确认输入触发keyup

chrome:输入触发keydown、keyup,回车确认输入只触发keydown

IE:输入触发keydown、keyup,回车确认输入触发keydown,keyup

Safari:输入触发keydown、keyup,回车确认输入触发keydown,keyup

opera:输入触发keydown、keyup,回车确认输入触发keydown,keyup

keypress事件不能对系统功能键(例如:后退、删除等,其中对中文输入法不能有效响应)进行正常的响应,

keydown和keyup均可以对系统功能键进行有效的拦截,但事件截获的位置不同。

键盘中的键分为字符(可打印)键和功能键(不可打印),系统功能键包括如下:

Esc、Tab、Caps Lock、Shift、Ctrl、Alt、Enter、Backspace、Print Screen、Scroll Lock、Pause Break、Insert、Delete、Home、End、Page Up、Page Down, F1through F12,Num Lock、The Arrow Keys。

keypress响应系统功能键总结:

Firefox:支持 Esc、Enter、Backspace、Pause Break、Insert、Delete、Home、End、Page Up、Page Down、F1 throughF12、The Arrow Keys

Chrome:支持Enter

Oprea:支持Enter

Safari:支持Enter

IE:支持Esc、Enter

ps:

firefox:上下左右键会触发kepress.

chrome: 上下左右键不会触发kepress.

oprea:上下左右键不会触发kepress.

safari:上下左右键不会触发kepress.

IE:上下左右键不会触发kepress.

=====================================================================

keyCode(键码), which, charCode(字符编码)

keydown: 获得keyCode, charCode=0

keypress: 字符(英文区分大小写+数字  / *, .  ...等非功能键),keyCode=0 ,获取charCode值,反之获取keyCode, charCode=0

keyup: 获得keyCode, charCode=0

jquery 中 event.which =original.charCode != null ? original.charCode : original.keyCode;

总结:回车、上下左右、等功能键keydown、keypress、keyup都获取keyCode,并且值相等。

 

开启大写情况,keydown、keypress(字母,主键盘数字、回车)、keyup,which值相等,小写kepress获取的which不同于keypress、keyup。

keypress事件的keyCode对字母的大小写敏感,而keydown、keyup事件不敏感

keypress事件的which值无法区分主键盘上的数字键和附键盘数字键的,而keydown、keyup的which值对主附键盘的数字键敏感。

IE(ie9以下)只有一个属性KeyCode属性,当为keydown和keyup 事件是,keycode属性表示你具体按下的键(也称为virtualkeycode),当捕捉的是keypress事件时keyCode属性指的是你键入的字符(character code)   

 

标准浏览器中情况有些不同,event对象包含一个keyCode属性和一个charCode属性,keydown和keyup事件的时候,keyCode表示的就是你具体按的键,charCode为0;当捕捉的是keypress事件时,keyCode为0,charCode指的是你按下的字符,鉴于IE和FF中的区别,如果你比较懒的话,建议只使用keydow和keyup事件

 

转载地址:http://www.cnblogs.com/silence516/archive/2013/01/25/2876611.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值