jQuery處理鍵盤事件,比如小說網(wǎng)站中常見的按左右鍵來實(shí)現(xiàn)上一篇文章和下一篇文章,按ctrl+回車實(shí)現(xiàn)表單提交,google reader和有道閱讀中的全快捷鍵操作...
jQuery處理鍵盤事件有三個(gè)函數(shù),根據(jù)事件發(fā)生的順序分別是:
keydown(); keyup(); keypress();
keydown()
keydown事件會(huì)在鍵盤按下時(shí)觸發(fā),可以在綁定的函數(shù)中歐能夠返回false來防止觸發(fā)瀏覽器的默認(rèn)事件.
keyup()
keyup事件會(huì)在按鍵釋放時(shí)觸發(fā),也就是你按下鍵盤起來后的事件
keypress()
keypress事件會(huì)在敲擊按鍵時(shí)觸發(fā),我們可以理解為按下并抬起同一個(gè)按鍵
我們?cè)趺床拍塬@取我按下的是A還是Z還是回車按鈕呢?
鍵盤事件可以傳遞一個(gè)參數(shù)event,其實(shí)說有的jQuery事件函數(shù)中都可以傳遞這么一個(gè)參數(shù)
$('input').keydown(function(event){
alert(event.keyCode);
});
上面代碼中的,event.keyCode就可以幫助我們獲取到我們按下了什么按鍵,他返回的是ascII碼,比如說上下左右鍵,分別是38,40,37,39
如果我們要實(shí)現(xiàn)ctrl+Enter就是ctrl+回車提交表單
$(document).keypress(function(e) {
if (e.ctrlKey && e.which == 13)
$("form").submit();
})
通過上下鍵選擇 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www./TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www./1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>無標(biāo)題文檔</title> <script type="text/javascript" src="jquery-1.7.2.js"></script> </head> <script language = "javascript" type = "text/javascript"> function ShowSelectItem(divId) { $("#hint div").css("background-color", "#ccc"); $("#" + divId).css("background-color", "#f00"); $("#search").val($("#" + divId).text()); //$('#hint').css('display','none') $('#search').focus(function(){ $('#hint').css('display','block') }).blur(function(){ $('#hint').css('display','none') }) } function SelectItemEvent() { var items = $("#hint div"); var selected = 1; //默認(rèn)選第一個(gè) ShowSelectItem(selected);
//捕捉鍵盤事件 上下左右分別為:38 40 37 39 $(document).keydown( function (event) { if (event.keyCode == 38) { //按了上箭頭 selected--; if (selected < 1) selected = 5; ShowSelectItem(selected); } else if (event.keyCode == 40) { //按了下箭頭 selected++; if(selected > 5) selected = 1; ShowSelectItem(selected); } }); }
$(document).ready(function() { SelectItemEvent(); });
</script>
<body>
<input type = "text" id = "search" onmousemove="showslect"/> <div id= "hint" style ="width : 200px; border : solid 1px Black;"> <div id = "1">選項(xiàng)1</div> <div id = "2">選項(xiàng)2</div> <div id = "3">選項(xiàng)3</div> <div id = "4">選項(xiàng)4</div> <div id = "5">選項(xiàng)5</div> </div>
</body> </html>
|