JavaScript 中keyup,keydown,keypress
来源:互联网 发布:java直播网站源码 编辑:程序博客网 时间:2024/04/29 11:31
js keyup、keypress和keydown事件 详解
js keyup、keypress和keydown事件都是有关于键盘的事件
当一个按键被pressed 或released在每一个现代浏览器中,都可能有三种客户端事件。
- keydown event
- keypress event
- keyup event
keydown事件发生在键盘的键被按下的时候,接下来触发keypress事件。 keyup 事件在按键被释放的时候触发。
这三个事件在页面中的使用方法如下例:
<input id="testkeyevent" name="testkeyevent" onKeyUp="keyup()" />
<input id="testkeyevent" name="testkeyevent" onkeypress="keypress()" />
<input id="testkeyevent" name="testkeyevent" onkeydown="keydown()" />
对应的js函数:
function keyup(){ ...}
function keypress(){ ...}
function keydown(){ ...}
注意:
- KeyDown触发后,不一定触发KeyUp,当KeyDown 按下后,拖动鼠标,那么将不会触发KeyUp事件。
- KeyPress主要用来捕获数字(注意:包括Shift+数字的符号)、字母(注意:包括大小写)、小键盘等除了F1-12、SHIFT、Alt、Ctrl、Insert、Home、PgUp、Delete、End、PgDn、ScrollLock、Pause、NumLock、{菜单键}、{开始键}和方向键外的ANSI字符
- KeyDown 和KeyUp 通常可以捕获键盘除了PrScrn所有按键(这里不讨论特殊键盘的特殊键)
- KeyPress 只能捕获单个字符
- KeyDown 和KeyUp 可以捕获组合键。
- KeyPress 可以捕获单个字符的大小写
- KeyDown和KeyUp 对于单个字符捕获的KeyValue 都是一个值,也就是不能判断单个字符的大小写。
- KeyPress 不区分小键盘和主键盘的数字字符。
- KeyDown 和KeyUp 区分小键盘和主键盘的数字字符。
- 其中PrScrn 按键KeyPress、KeyDown和KeyUp 都不能捕获。
在使用键盘的时候,通常会使用到CTRL+SHIFT+ALT 类似的组合键功能。对于此,我们如何来判定?
通过KeyUp 事件能够来处理(这里说明一下为什么不用KeyDown,因为在判定KeyDown的时候,CTRL、SHIFT和ALT 属于一直按下状态,然后再加另外一个键是不能准确捕获组合键,所以使用KeyDown 是不能准确判断出的,要通过KeyUp 事件来判定 )
这里简单的列举出CTRL+其它键的组合判定代码:
private void Form3_KeyUp(object sender, KeyEventArgs e)
{
if (e.Control)
{
MessageBox.Show("KeyUp:Ctrl+" + e.KeyValue.ToString());
}
}- 捕获PrScrn按键事件
通过一种钩子的方式可以判定PrScrn 按键事件,钩子可以获取任何键盘事件。
- JavaScript 中keyup,keydown,keypress
- JavaScript 的keydown,keypress,keyup事件
- c# 中 KeyPress 和KeyDown 、KeyUp
- keydown keypress keyup
- Keypress,KeyUp,KeyDown
- KeyDown,KeyPress 和 KeyUp
- KeyDown、KeyUp、KeyPress区别
- KeyDown,KeyPress 和KeyUp
- keydown keypress keyup事件
- keypress,keydown,keyup问题
- javascript keypress与keydown和keyup的区别
- javascript KeyDown、KeyPress和KeyUp事件的区别与联系
- 关于KeyPress,KeyDown和KeyUp
- KeyDown,KeyPress 和KeyUp详解
- KeyDown,KeyPress和KeyUp详解
- 转载: c# keydown keypress keyup
- c# KeyDown,KeyPress 和KeyUp
- 键盘事件keydown、keypress、keyup
- cocos2d-x 图片数字显示,可用于计分板,金币显示板等
- android Expandablelistview的子item点击没有效果
- 寻找逆序对的算法,要求运行时间为O(nlgn),算法导论答案
- 自定义面板类Panel
- 回顾 Exchange 2007 SCC 安装-供需要的人参考!
- JavaScript 中keyup,keydown,keypress
- jQuery.extend 函数详解
- DroidBox
- windows核心编程-互斥器(Mutexes)
- Andrew Stankevich's Contest #8 Solution
- poj Dropping tests 01分数规划---Dinkelbach算法
- poj 1308
- java邮件开发
- 使用javabean实现分页