jquery利用event.which方法獲取鍵盤輸入值的代碼
更新時(shí)間:2011年10月09日 00:16:21 作者:
jquery利用event.which方法獲取鍵盤輸入值的代碼,需要的朋友可以參考下。
實(shí)例
顯示按了哪個(gè)鍵:
$("input").keydown(function(event){
$("div").html("Key: " + event.which);
});
親自試一試
定義和用法
which 屬性指示按了哪個(gè)鍵或按鈕。
語法
event.which參數(shù) 描述
event 必需。規(guī)定要檢查的事件。這個(gè) event 參數(shù)來自事件綁定函數(shù)。
jQuery丟棄了標(biāo)準(zhǔn)的 button 屬性采用 which,這有點(diǎn)讓人費(fèi)解。
which 是Firefox引入的,IE不支持。which的本意是獲取鍵盤的鍵值(keyCode)。
jQuery中的which即可以是鍵盤的鍵值,也可以是鼠標(biāo)的鍵值。
即當(dāng)判斷用戶按下鍵盤的哪個(gè)鍵時(shí)可以使用which,當(dāng)判斷用戶按下鼠標(biāo)的哪個(gè)鍵時(shí)也可以用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 ) ));
}
標(biāo)準(zhǔn)的button采用0,1,2表示鼠標(biāo)的左,中,右鍵。jQuery的which則使用用1,2,3。
還有一點(diǎn)讓人不爽的是jQuery文檔 event.which 中并沒有提到which可以表示鼠標(biāo)按鍵值,只提到了表示鍵盤按鍵值。
源碼中的注釋也讓人誤解。
// Add which for click: 1 === left; 2 === middle; 3 === right
注意這里說的是click ,很容易讓人使用click 事件,但實(shí)際上click事件中獲取是錯(cuò)誤的。
下面就用 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>
顯示按了哪個(gè)鍵:
$("input").keydown(function(event){
$("div").html("Key: " + event.which);
});
親自試一試
定義和用法
which 屬性指示按了哪個(gè)鍵或按鈕。
語法
event.which參數(shù) 描述
event 必需。規(guī)定要檢查的事件。這個(gè) event 參數(shù)來自事件綁定函數(shù)。
jQuery丟棄了標(biāo)準(zhǔn)的 button 屬性采用 which,這有點(diǎn)讓人費(fèi)解。
which 是Firefox引入的,IE不支持。which的本意是獲取鍵盤的鍵值(keyCode)。
jQuery中的which即可以是鍵盤的鍵值,也可以是鼠標(biāo)的鍵值。
即當(dāng)判斷用戶按下鍵盤的哪個(gè)鍵時(shí)可以使用which,當(dāng)判斷用戶按下鼠標(biāo)的哪個(gè)鍵時(shí)也可以用which。它一舉兩用了。
源碼:
復(fù)制代碼 代碼如下:
// 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 ) ));
}
標(biāo)準(zhǔn)的button采用0,1,2表示鼠標(biāo)的左,中,右鍵。jQuery的which則使用用1,2,3。
還有一點(diǎn)讓人不爽的是jQuery文檔 event.which 中并沒有提到which可以表示鼠標(biāo)按鍵值,只提到了表示鍵盤按鍵值。
源碼中的注釋也讓人誤解。
// Add which for click: 1 === left; 2 === middle; 3 === right
注意這里說的是click ,很容易讓人使用click 事件,但實(shí)際上click事件中獲取是錯(cuò)誤的。
下面就用 click 事件試試:
復(fù)制代碼 代碼如下:
<!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>
您可能感興趣的文章:
- Jquery中Event對(duì)象屬性小結(jié)
- jquery事件preventDefault()方法用法實(shí)例
- jQuery.event兼容各瀏覽器的event詳細(xì)解析
- jquery中event對(duì)象屬性與方法小結(jié)
- JQuery事件e參數(shù)的方法preventDefault()取消默認(rèn)行為
- jquery 關(guān)于event.target使用的幾點(diǎn)說明介紹
- Jquery阻止事件冒泡 event.stopPropagation
- jquery下為Event handler傳遞動(dòng)態(tài)參數(shù)的代碼
- jQuery源碼分析之Event事件分析
- Jquery替換已存在于element上的event的方法
- 利用jQuery的$.event.fix函數(shù)統(tǒng)一瀏覽器event事件處理
- jQuery.event.trigger()的簡(jiǎn)單解釋
相關(guān)文章
jQuery DataTables插件自定義Ajax分頁實(shí)例解析
這篇文章主要為大家詳細(xì)介紹了jQuery DataTables插件自定義Ajax分頁的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05jQuery擴(kuò)展_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要介紹了jQuery擴(kuò)展,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07使用jquery選擇器如何獲取父級(jí)元素、同級(jí)元素、子元素
這篇文章主要介紹了使用jquery選擇器如何獲取父級(jí)元素、同級(jí)元素、子元素,需要的朋友可以參考下2014-05-05jQuery插件ajaxfileupload.js實(shí)現(xiàn)上傳文件
這篇文章主要為大家詳細(xì)介紹了jQuery插件ajaxfileupload.js實(shí)現(xiàn)上傳文件的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-05-05boxy基于jquery的彈出層對(duì)話框插件擴(kuò)展應(yīng)用 彈出層選擇器
當(dāng)大家進(jìn)行復(fù)雜功能設(shè)計(jì)的時(shí)候,在對(duì)多級(jí)聯(lián)選擇進(jìn)行設(shè)計(jì),為了獲得更好的用戶體驗(yàn)和節(jié)省頁面空間,往往會(huì)使用彈出層的方法。2010-11-11