keyCode 事件屬性

事件對(duì)象參考手冊(cè) 事件對(duì)象

實(shí)例

獲取按下的鍵盤按鍵Unicode值:

var x = event.keyCode;

x 輸出結(jié)果為:

119   // 119 是字符"w"

嘗試一下 ?

本文底部包含了更多實(shí)例。


定義和使用

keyCode 屬性返回onkeypress事件觸發(fā)的鍵的值的字符代碼,或者 onkeydownonkeyup 事件的鍵的代碼。

兩種代碼類型的區(qū)別是:

  • 字符代碼 - 表示 ASCII 字符的數(shù)字
  • 鍵盤代碼 - 表示鍵盤上真實(shí)鍵的數(shù)字
p>兩種類型的值不是都相等的,例如小寫字符"w" 和大寫字符 "W" 有相同的鍵盤代碼,因?yàn)樗麄兯麄冩I盤上 ( "W" 代碼為 "87"),但是它們有不同的字符代碼,兩個(gè)字符輸出是不一樣的( "w" 和 "W" 字符代碼為"119" 和 "87") - 查看以下實(shí)例可以更好的理解。

提示: 如果需要知道用戶按下的是打印鍵 (如 "a" 或 "5"),建議使用 onkeypress 事件。如果需要知道用戶按下的是功能鍵(如 "F1", "CAPS LOCK" 或 "Home") 可使用 onkeydown 或 onkeyup 事件。

注意: 在 Firefox 中,, keyCode 屬性在onkeypress 事件中是無效的 (返回 0)。瀏覽器兼容問題,可以一起使用which 和 keyCode 屬性來解決:

var x = event.which || event.keyCode;  // 使用 whichkeyCode, 這樣可支持不同瀏覽器

提示: 所有 Unicode 字符列表可查看我們的完整 Unicode 參考手冊(cè)。

提示: 如果你需要將 Unicode 值轉(zhuǎn)換為字符,可以使用 fromCharCode() 方法。

注意: 該屬性是只讀的。

注意: which 和 keyCode 屬性提供了解決瀏覽器的兼容性的方法,最新版本的 DOM 事件推薦使用key 屬性來替代該方法。

提示: 如果你想查看是否按下了 "ALT", "CTRL", "META" 或 "SHIFT" 鍵,可使用altKey, ctrlKey, metaKeyshiftKey 屬性。


瀏覽器支持

屬性          
keyCode Yes Yes Yes Yes Yes


語法

event.keyCode

技術(shù)細(xì)節(jié)

返回值:數(shù)字,表示 Unicode 字符代碼或 Unicode 鍵代碼
DOM 版本:DOM Level 2 Events


實(shí)例

更多實(shí)例

實(shí)例

使用 onkeypress 和 onkeydown 來演示字符代碼與鍵盤代碼的區(qū)別:

<input type="text" onkeypress="uniCharCode(event)" onkeydown="uniKeyCode(event)">

function uniCharCode(event) {
    var char = event.which || event.keyCode;
    document.getElementById("demo").innerHTML = "Unicode CHARACTER code: " + char;
}

function uniKeyCode(event) {
    var key = event.keyCode;
    document.getElementById("demo2").innerHTML = "Unicode KEY code: " + key;
}

當(dāng)在鍵盤上按下 "a" 鍵 (不使用大寫鎖定), 輸出結(jié)果如下:

Unicode 字符代碼: 97
Unicode 鍵代碼: 65

嘗試一下 ?

實(shí)例

如果按下 Esc 鍵彈出提示信息:

<input type="text" onkeydown="myFunction(event)">

function myFunction(event) {
    var x = event.keyCode;
    if (x == 27) {  // 27 是 ESC 鍵
        alert ("You pressed the Escape key!");
    }
}

嘗試一下 ?

實(shí)例

將 Unicode 值轉(zhuǎn)換為字符 (不能用于功能鍵):

var x = event.keyCode;                // 獲取 Unicode 值
var y = String.fromCharCode(x);       // 將值轉(zhuǎn)換為字符

嘗試一下 ?


相關(guān)頁面

HTML DOM 參考手冊(cè): key 事件屬性

HTML DOM 參考手冊(cè): keyCode 事件屬性

HTML DOM 參考手冊(cè): which 事件屬性

事件對(duì)象參考手冊(cè) 事件對(duì)象