首页 > 代码库 > 检测键盘按键(三)——keypress和keydown、keyup

检测键盘按键(三)——keypress和keydown、keyup

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

在IE中Esc有值,Chrome中不能触发。

FF都可以触发keypress,除了Alt、Ctrl、Shift键。

keypress可以捕获组合键,比如当用户按下shift + 1时,keypress是对这个按键事件进行解析后返回一个可打印的“!”字符,而keydown只能

输出1。

对于屏幕可打印字符时,keypress是首选。

keydown:通常可以捕获键盘除了PrScrn所有按键。不能判断单个字符的大小写。因此多用于捕获功能键。

PrScrn 按键KeyPress、KeyDown和KeyUp 都不能捕获。

<!DOCTYPE html><HTML><HEAD>    <meta charset="utf-8"></HEAD><BODY><script type="text/javascript">    var keystring = "";//记录按键的字符串    function $(s){return document.getElementById(s)?document.getElementById(s):s;}    function keypress(e)    {        var currKey=0,CapsLock=0,e=e||event;        currKey=e.keyCode||e.which||e.charCode;        CapsLock=currKey>=65&&currKey<=90;        switch(currKey)        {           //屏蔽了退格、制表、回车、空格、方向键、删除键             case 8: case 9:case 13:case 32:case 37:case 38:case 39:case 40:case 46:keyName = "";break;    default:keyName = String.fromCharCode(currKey); break;        }        keystring += keyName;    }    function keydown(e)    {        var e=e||event;        var currKey=e.keyCode||e.which||e.charCode;        if((currKey>7&&currKey<14)||(currKey>31&&currKey<47))        {            switch(currKey)                {                 case 8: keyName = "[退格]"; break;    case 9: keyName = "[制表]"; break;     case 13:keyName = "[回车]"; break;     case 32:keyName = "[空格]"; break;    case 33:keyName = "[PageUp]";   break;     case 34:keyName = "[PageDown]";   break;    case 35:keyName = "[End]";   break;     case 36:keyName = "[Home]";   break;     case 37:keyName = "[方向键左]";   break;     case 38:keyName = "[方向键上]";   break;     case 39:keyName = "[方向键右]";   break;      case 40:keyName = "[方向键下]";   break;     case 46:keyName = "[删除]";   break;     default:keyName = "";    break;                }                    keystring += keyName;            }            $("content").innerHTML=keystring;        }        function keyup(e)        {            $("content").innerHTML=keystring;        }        document.onkeypress=keypress;        document.onkeydown =keydown;        document.onkeyup =keyup;</script><input type="text" /><input type="button" value="清空记录" onclick="$(‘content‘).innerHTML = ‘‘;keystring = ‘‘;"/><br/>请按下任意键查看键盘响应键值:<span id="content"></span></BODY></HTML>