2025-05-23

jQuery丟棄瞭標準的 button 屬性采用 which,這有點讓人費解。


which 是Firefox引入的,IE不支持。which的本意是獲取鍵盤的鍵值(keyCode)。


jQuery中的which即可以是鍵盤的鍵值,也可以是鼠標的鍵值。
即當判斷用戶按下鍵盤的哪個鍵時可以使用which,當判斷用戶按下鼠標的哪個鍵時也可以用which。它一舉兩用瞭。


源碼


view sourceprint?01 // Add which for key events 


02 if ( event.which == null && (event.charCode != null || event.keyCode != null) ) { 


03     event.which = event.charCode != null ? event.charCode : event.keyCode; 


04 } 


05   


06 // Add which for click: 1 === left; 2 === middle; 3 === right 


07 // Note: button is not normalized, so dont use it 


08 if ( !event.which && event.button !== undefined ) { 


09     event.which = (event.button & 1 ? 1 : ( event.button & 2 ? 3 : ( event.button & 4 ? 2 : 0 ) )); 


10 }


 


標準的button采用0,1,2表示鼠標的左,中,右鍵。jQuery的which則使用用1,2,3。


還有一點讓人不爽的是jQuery文檔 event.which 中並沒有提到which可以表示鼠標按鍵值,隻提到瞭表示鍵盤按鍵值。


源碼中的註釋也讓人誤解。


view sourceprint?1 // Add which for click: 1 === left; 2 === middle; 3 === right


註意這裡說的是click ,很容易讓人使用click 事件,但實際上click事件中獲取是錯誤的。


 下面就用 click 事件試試:


view sourceprint?01 <!DOCTYPE html> 


02 <html> 


03 <head> 


04 <meta charset=”utf-8″/> 


05 <title></title> 


06 <script src=”https://code.jquery.com/jquery-1.6.1.js”></script> 


07 <script type=”text/javascript”> 


08     $(document).click(function(e){ 


09         alert(e.which); 


10     })   


11   


12 </script> 


13 </head> 


14 <body> 


15 </body> 


16 </html>



測試結果  IE6/7/8 IE9 Firefox4 Chrome12 Safari Opera
點擊左鍵 0 1 1 1 1(不停彈出alert) 1
點擊中鍵 不響應 2 2 2 2(不停彈出alert) 不響應
點擊右鍵 僅彈出右鍵菜單 僅彈出右鍵菜單 3,彈出右鍵菜單 僅彈出右鍵菜單 僅彈出右鍵菜單 僅彈出右鍵菜單



可以看到使用 click 事件並不能按照jQuery設想的那樣左,中,右鍵對應的1,2,3值。各瀏覽器下均不一致,且右鍵根本獲取不到,Safari中還不停的彈出alert。


因此,應該使用 mousedown / mouseup 事件則達到jQuery的設想。jQuery的註釋誤導瞭人。


此外即使使用 mousedown / mouseup 事件,Opera中也無法獲取中鍵的值。Opera的惡心做法令jQuery也無能為力。


 


 

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *