keyCode 事件屬性
本文底部包含了更多實例。
定義和使用
keyCode 屬性返回onkeypress事件觸發(fā)的鍵的值的字符代碼,或者 onkeydown 或 onkeyup 事件的鍵的代碼。
兩種代碼類型的區(qū)別是:
- 字符代碼 - 表示 ASCII 字符的數(shù)字
- 鍵盤代碼 - 表示鍵盤上真實鍵的數(shù)字
提示: 如果需要知道用戶按下的是打印鍵 (如 "a" 或 "5"),建議使用 onkeypress 事件。如果需要知道用戶按下的是功能鍵(如 "F1", "CAPS LOCK" 或 "Home") 可使用 onkeydown 或 onkeyup 事件。
注意: 在 Firefox 中,, keyCode 屬性在onkeypress 事件中是無效的 (返回 0)。瀏覽器兼容問題,可以一起使用which 和 keyCode 屬性來解決:
提示: 所有 Unicode 字符列表可查看我們的完整 Unicode 參考手冊。
提示: 如果你需要將 Unicode 值轉換為字符,可以使用 fromCharCode() 方法。
注意: 該屬性是只讀的。
注意: which 和 keyCode 屬性提供了解決瀏覽器的兼容性的方法,最新版本的 DOM 事件推薦使用key 屬性來替代該方法。
提示: 如果你想查看是否按下了 "ALT", "CTRL", "META" 或 "SHIFT" 鍵,可使用altKey, ctrlKey, metaKey 或shiftKey 屬性。
瀏覽器支持
屬性 | |||||
---|---|---|---|---|---|
keyCode | Yes | Yes | Yes | Yes | Yes |
語法
技術細節(jié)
返回值: | 數(shù)字,表示 Unicode 字符代碼或 Unicode 鍵代碼 |
---|---|
DOM 版本: | DOM Level 2 Events |
更多實例
實例
使用 onkeypress 和 onkeydown 來演示字符代碼與鍵盤代碼的區(qū)別:
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;
}
當在鍵盤上按下 "a" 鍵 (不使用大寫鎖定), 輸出結果如下:
Unicode 鍵代碼: 65
嘗試一下 ?
實例
如果按下 Esc 鍵彈出提示信息:
function myFunction(event) {
var x = event.keyCode;
if (x == 27) { // 27 是 ESC 鍵
alert ("You pressed the Escape key!");
}
}
嘗試一下 ?
實例
將 Unicode 值轉換為字符 (不能用于功能鍵):
var y = String.fromCharCode(x); // 將值轉換為字符
嘗試一下 ?
相關頁面
HTML DOM 參考手冊: key 事件屬性
HTML DOM 參考手冊: keyCode 事件屬性
HTML DOM 參考手冊: which 事件屬性
更多建議: