jquery快捷動態綁定鍵盤事件操作函數



;(function($)
{
    $.extend({
        
		key_fn:[],		//存放綁定的字符對應的函數
		key_code:[],		//存放字符
		key_bind:function(ch,callback){
	var KeyCode = {a:65,b:66,c:67,d:68,e:69,f:70,g:71,h:72,i:73,j:74,k:75,l:76,m:77,n:78,o:79,p:80,q:81,r:82,s:83,t:84,u:85,v:86,w:87,x:88,y:89,z:90};
				 
				if(KeyCode.hasOwnProperty(ch)){
					 $.key_fn.push(callback);
					 $.key_code.push(ch);
					 //第一次才需要添加事件
					 if($.key_fn.length == 1){
					 
						$(document).keypress(function(e){
							var e = event || window.event; 
							var k = e.keyCode || e.which; 
							
							 for(var i =0 ; i < $.key_fn.length ;i++){
								
								 // - 32 兼容小寫
								if(k-32 == KeyCode[$.key_code[i]] || k == KeyCode[$.key_code[i]] ){
									log('pressed binded key '+k);
									$.key_fn[i]();
									break;
								}
							}
							
						});
					}
				}else
				{
					alert('綁定事件只能是字母');
				}
		}
		
    });
})(jQuery);  


使用的時候可以如下

$.key_bind('f',set_table_full_screen);
$.key_bind('r',reloadthis);

有時候我們需要爲應用添加一些快捷方式,每次都去寫一個下面的代碼,通過key_bin就是方便的綁定某個鍵盤和和對應的操作函數了。
$(document).keypress(function(){})

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章