jquery利用event.which方法如何获取键盘输入值
2011-10-14 13:38
691 查看
jquery利用event.which方法如何获取键盘输入值
实例
显示按了哪个键:
$("input").keydown(function(event){
$("div").html("Key: " + event.which);
});
亲自试一试
定义和用法
which 属性指示按了哪个键或按钮。
语法
event.which参数 描述
event 必需。规定要检查的事件。这个 event 参数来自事件绑定函数。
jQuery丢弃了标准的 button 属性采用 which,这有点让人费解。
which 是Firefox引入的,IE不支持。which的本意是获取键盘的键值(keyCode)。
jQuery中的which即可以是键盘的键值,也可以是鼠标的键值。
即当判断用户按下键盘的哪个键时可以使用which,当判断用户按下鼠标的哪个键时也可以用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 ) ));
}
标准的button采用0,1,2表示鼠标的左,中,右键。jQuery的which则使用用1,2,3。
还有一点让人不爽的是jQuery文档 event.which 中并没有提到which可以表示鼠标按键值,只提到了表示键盘按键值。
源码中的注释也让人误解。
// Add which for click: 1 === left; 2 === middle; 3 === right
注意这里说的是click ,很容易让人使用click 事件,但实际上click事件中获取是错误的[在FF下是OK的,但在IE下会出现问题,因为event的button属性是针对mousedown 和 mouseup事件的,因此在click事件下,button属性本身都错误的,[b]而which源自对button属性的分析,故which也有错。
注意:The button property is set for onmousedown and onmouseup events in all browsers. ->
http://help.dottoro.com/ljaxplfi.php ][/b]。
下面就用 click 事件试试:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title></title>
<script src="http://www.3ppt.com/jquery-1.6.1.js"></script>
<script type="text/css">
$(document).click(function(e){
//修改为 $(document).mousedown( function (e) { 就OK
alert(e.which);
})
</script>
</head>
<body>
</body>
</html>
实例
显示按了哪个键:
$("input").keydown(function(event){
$("div").html("Key: " + event.which);
});
亲自试一试
定义和用法
which 属性指示按了哪个键或按钮。
语法
event.which参数 描述
event 必需。规定要检查的事件。这个 event 参数来自事件绑定函数。
jQuery丢弃了标准的 button 属性采用 which,这有点让人费解。
which 是Firefox引入的,IE不支持。which的本意是获取键盘的键值(keyCode)。
jQuery中的which即可以是键盘的键值,也可以是鼠标的键值。
即当判断用户按下键盘的哪个键时可以使用which,当判断用户按下鼠标的哪个键时也可以用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 ) ));
}
标准的button采用0,1,2表示鼠标的左,中,右键。jQuery的which则使用用1,2,3。
还有一点让人不爽的是jQuery文档 event.which 中并没有提到which可以表示鼠标按键值,只提到了表示键盘按键值。
源码中的注释也让人误解。
// Add which for click: 1 === left; 2 === middle; 3 === right
注意这里说的是click ,很容易让人使用click 事件,但实际上click事件中获取是错误的[在FF下是OK的,但在IE下会出现问题,因为event的button属性是针对mousedown 和 mouseup事件的,因此在click事件下,button属性本身都错误的,[b]而which源自对button属性的分析,故which也有错。
注意:The button property is set for onmousedown and onmouseup events in all browsers. ->
http://help.dottoro.com/ljaxplfi.php ][/b]。
下面就用 click 事件试试:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"/>
<title></title>
<script src="http://www.3ppt.com/jquery-1.6.1.js"></script>
<script type="text/css">
$(document).click(function(e){
//修改为 $(document).mousedown( function (e) { 就OK
alert(e.which);
})
</script>
</head>
<body>
</body>
</html>
相关文章推荐
- jquery利用event.which方法如何获取键盘输入值
- jquery利用event.which方法获取键盘输入值的代码
- jquery利用event.which方法获取键盘输入值的代码
- jquery利用event.which方法获取键盘输入值的代码
- event.keyCode ,event.which ,event.charCode获取键盘输入
- Unix下如何直接获取键盘输入而不需要以回车作为结束符的方法总结
- 如何通过JAVA获取键盘输入值几种方法介绍
- jquery event.which 获取用户按下键盘值
- JQuery下focus()无法自动获取焦点的处理方法 jquery如何使文本框获得焦点
- Java中获取键盘输入值的三种方法
- Java中获取键盘输入值的三种方法
- JQuery下focus()无法自动获取焦点的处理方法 jquery如何使文本框获得焦点
- Java中获取键盘输入值的三种方法
- Java中获取键盘输入值的三种方法
- Java中的Scanner类的用法以及其他获取键盘输入的方法
- js获取键盘按下的键值event.keyCode,event.charCode,event.which的兼容性
- Java中获取键盘输入值的三种方法
- Jquery学习笔记:利用parent和parents方法获取父节点
- Java中获取键盘输入值的三种方法
- Java获取键盘输入值的三种方法