執行個體
顯示按了哪個鍵:
$("input").keydown(function(event){
$("div").html("Key: " + event.which);
});
親自試一試
定義和用法
which 屬性指示按了哪個鍵或按鈕。
文法
event.which參數 描述
event 必需。規定要檢查的事件。這個 event 參數來自事件綁定函數。
jQuery丟棄了標準的 button 屬性採用 which,這有點讓人費解。
which 是Firefox引入的,IE不支援。which的本意是擷取鍵盤的索引值(keyCode)。
jQuery中的which即可以是鍵盤的索引值,也可以是滑鼠的索引值。
即當判斷使用者按下鍵盤的哪個鍵時可以使用which,當判斷使用者按下滑鼠的哪個鍵時也可以用which。它一舉兩用了。
源碼:
複製代碼 代碼如下:
// Add which for key events
if ( event.which == null && (event.charCode != null || event.keyCode != null) ) {
event.which = event.charCode != null ? event.charCode : event.keyCode;
}
// Add which for click: 1 === left; 2 === middle; 3 === right
// Note: button is not normalized, so don't use it
if ( !event.which && event.button !== undefined ) {
event.which = (event.button & 1 ? 1 : ( event.button & 2 ? 3 : ( event.button & 4 ? 2 : 0 ) ));
}
標準的button採用0,1,2表示滑鼠的左,中,右鍵。jQuery的which則使用用1,2,3。
還有一點讓人不爽的是jQuery文檔 event.which 中並沒有提到which可以表示滑鼠按索引值,只提到了表示鍵盤按索引值。
源碼中的注釋也讓人誤解。
// Add which for click: 1 === left; 2 === middle; 3 === right
注意這裡說的是click ,很容易讓人使用click 事件,但實際上click事件中擷取是錯誤的。
下面就用 click 事件試試:
複製代碼 代碼如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title></title>
<script src="http://demo.jb51.net/jslib/jquery/jquery-1.6.1.js"></script>
<script type="text/css">
$(document).click(function(e){
alert(e.which);
})
</script>
</head>
<body>
</body>
</html>