jquery快捷动态绑定键盘事件的操作函数代码


Posted in Javascript onOctober 17, 2013
(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(){})
Javascript 相关文章推荐
JavaScript 入门·JavaScript 具有全范围的运算符
Oct 01 Javascript
javascript权威指南 学习笔记之null和undefined
Sep 25 Javascript
js用Date对象处理时间实现思路及代码
Jan 31 Javascript
JS+CSS设置img在DIV中只显示Img垂直居中的部分
Oct 24 Javascript
jQuery获取和设置表单元素的方法
Feb 14 Javascript
textarea不能通过maxlength属性来限制字数的解决方法
Sep 01 Javascript
javascript几个易错点记录
Nov 26 Javascript
微信小程序本地缓存数据增删改查实例详解
May 24 Javascript
解决vue A对象赋值给B对象,修改B属性会影响到A的问题
Sep 25 Javascript
Postman如何实现参数化执行及断言处理
Jul 28 Javascript
js实现炫酷光感效果
Sep 05 Javascript
通过滑动翻页效果实现和移动端click事件问题
Jan 26 Javascript
js实现的常用的左侧导航效果
Oct 17 #Javascript
给超链接添加特效鼠标移动展示提示信息且随鼠标移动
Oct 17 #Javascript
JS对HTML标签select的获取、添加、删除操作
Oct 17 #Javascript
JS操作数据库的实例代码
Oct 17 #Javascript
JavaScript调用后台的三种方法实例
Oct 17 #Javascript
9行javascript代码获取QQ群成员具体实现
Oct 16 #Javascript
JS实现时间格式化的方式汇总
Oct 16 #Javascript
You might like
php小技巧之过滤ascii控制字符
2014/05/14 PHP
PHP异步进程助手async-helper
2018/02/05 PHP
网页图片延时加载的js代码
2010/04/22 Javascript
jQuery UI Autocomplete 体验分享
2012/02/14 Javascript
JS清除IE浏览器缓存的方法
2013/07/26 Javascript
JS格式化数字保留两位小数点示例代码
2013/10/15 Javascript
JavaScript中instanceof运算符的用法总结
2013/11/19 Javascript
使用jQuery快速解决input中placeholder值在ie中无法支持的问题
2014/01/02 Javascript
js数组去重的方法汇总
2015/07/29 Javascript
js检测离开或刷新页面时表单数据是否更改的方法
2016/08/02 Javascript
JavaScript登录验证基础教程
2017/11/01 Javascript
webpack配置打包后图片路径出错的解决
2018/04/26 Javascript
vue+axios新手实践实现登陆的示例代码
2018/06/06 Javascript
jQuery+css实现的点击图片放大缩小预览功能示例【图片预览 查看大图】
2020/05/29 jQuery
[02:23]2016国际邀请赛中国区预选赛wings晋级之路
2016/06/29 DOTA
Python下的twisted框架入门指引
2015/04/15 Python
Django实战之用户认证(用户登录与注销)
2018/07/16 Python
python调用摄像头显示图像的实例
2018/08/03 Python
Python基于scipy实现信号滤波功能
2019/05/08 Python
通过Python编写一个简单登录功能过程解析
2019/09/04 Python
Python转换itertools.chain对象为数组的方法
2020/02/07 Python
Python 写了个新型冠状病毒疫情传播模拟程序
2020/02/14 Python
Python简单实现词云图代码及步骤解析
2020/06/04 Python
分享unittest单元测试框架中几种常用的用例加载方法
2020/12/02 Python
css3实现超立体3D图片侧翻倾斜效果
2014/04/16 HTML / CSS
伦敦时尚生活的缩影:LN-CC
2017/01/24 全球购物
英国经典球衣网站:Classic Football Shirts
2017/05/20 全球购物
Expedia韩国官网:亚洲发展最快的在线旅游门户网站
2018/02/26 全球购物
澳洲本土太阳镜品牌:Quay Australia
2019/07/29 全球购物
党的群众路线教育实践活动查摆问题及整改措施
2014/10/10 职场文书
成都人事代理协议书
2014/10/25 职场文书
《鲸》教学反思
2016/02/23 职场文书
python实现批量提取指定文件夹下同类型文件
2021/04/05 Python
Go 在 MongoDB 中常用查询与修改的操作
2021/05/07 Golang
解读Vue组件注册方式
2021/05/15 Vue.js
Pytorch可视化的几种实现方法
2021/06/10 Python