代码改变世界

【javascript基础】keypress keydown keyup的区别

2012-11-13 11:02  sniper007  阅读(479)  评论(0编辑  收藏  举报
一、定义:

KeyDown:在控件有焦点的情况下按下键时发生。

KeyPress:在控件有焦点的情况下按下键时发生。(下面会说和KeyDown 的区别)

KeyUp:在控件有焦点的情况下释放键时发生。


 二、促发的顺序:

 

  1. KeyDown

  2. KeyPress

  3. KeyUp

 demo :

 

 

<input type="text" id="wrap" />

<script type="text/javascript">

function $(str){
    return document.getElementById(str);
}

$("wrap")["onkeyup"] = function(){
    console.log("促发的是keyup");
    console.warn("-------------------------------------");
};

$("wrap")["onkeypress"] = function(){
    console.log("促发的是keypress");
};

$("wrap")["onkeydown"] = function(){
    console.log("促发的是keydown");
};

</script>

 

 

三、三者之间的区别:

 

1.KeyPress主要用来捕获数字(注意:包括Shift+数字的符号)、字母(注意:包括大小写)、小键盘等除了F1-12、SHIFT、Alt、Ctrl、Insert、Home、PgUp、Delete、End、PgDn、ScrollLock、Pause、NumLock、{菜单键}、{开始键}和方向键外的ANSI字符 

KeyDown 和KeyUp 通常可以捕获键盘除了PrScrn所有按键(这里不讨论特殊键盘的特殊键)

demo:

下面的例子就测试下大小写,其他的可以自己测试,我前后输入大小写的q、Q,结果如下图,keypress区分大小写,并且通过charCode反应出来,keydown,keyup不区分大小写,前后keyCode都一样

 

 

<input type="text" id="wrap" />

<script type="text/javascript">

function $(str){
    return document.getElementById(str);
}

$("wrap")["onkeyup"] = function(event){
    event = event || window.event;
    console.info(event);
    console.log("促发的是keyup");
    console.warn("-------------------------------------");
};

$("wrap")["onkeypress"] = function(event){
    event = event || window.event;
    console.info(event);
    console.log("促发的是keypress");
};

$("wrap")["onkeydown"] = function(event){
    event = event || window.event;
    console.info(event);
    console.log("促发的是keydown");
};

</script>

 

 

 

 

 

 

 

2.KeyPress 只能捕获单个字符KeyDown 和KeyUp 可以捕获组合键。

 

 

 

3.KeyPress 可以捕获单个字符的大小写(详见第一个区别)

4.KeyDown和KeyUp 对于单个字符捕获的KeyValue 都是一个值,也就是不能判断单个字符的大小写。

(详见第一个区别)

 

5.KeyPress 不区分小键盘和主键盘的数字字符。KeyDown 和KeyUp 区分小键盘和主键盘的数字字符。

我依次按主键盘1,小键盘1,区别如下

 

 

 

6.其中PrScrn 按键KeyPress、KeyDown和KeyUp 都不能捕获。

 

补充知识:键码、字符编码概念

键码:在发生keydown和keyup事件时,event对象的keyCode属性中会包含一个代码,与键盘上的一个特定的键相对应。对数字字母符键,keyCode属性的值与ASCII码中对应小写字母或者数字的编码相同。 因此,数字键7的keyCode的值为55,而字母A的keyCode的值是65,与shift键无关,DOM和IE的event对象都支持keyCode属性。

注意点:

1、在firefox和opera中,分号的keyCode为59,就是ASCII编码,但IE、safari返回186,即键盘中按键的键码。

2、在safari3之前的版本中,上、下、左、右箭头和上、下翻页键返回大于63000的值。

3、在opera9.5之前的版本中,会将非数字字母键的keyCode设置为等于相应字符的ASCII的编码,因此小于键返回44而不是188.这会影响到能产生一个非数字字母字符的所有键。

4、在safari3之前的版本中,不会因为按下制表、上档、控制或者替代键而促发keydown和keyup事件。

 

字符编码:

发生keypress事件意味着按下的键会影响到屏幕中文本的显示。

firefox,chrome,safari的event对象都支持一个keyCode的属性,这个属性只有在发生keypress事件时才包含值,而且这个值是按下的那个键所代表字符的ASCII的值。此时的keyCode等于0或者键的码值。IE和opera则是在keyCode中保存字符的ASCII编码。所以,兼容各种浏览器,代码如下:

 

function getCharCode(event){
    var ret;
    typeof event.charCode == "number" ? ret = event.charCode : ret = event.keyCode;
    return ret;
}

 

 

 参考文档:

http://blog.sina.com.cn/s/blog_5e3a1bbb0100esv3.html 

 

《javascript高级程序设计》第2版,第十二章事件 12.4.3键盘事件