js keyup、keypress和keydown事件 详解
来源:互联网 发布:淘宝免费推广的方法 编辑:程序博客网 时间:2024/05/01 15:16
js keyup、keypress和keydown事件 详解
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 按键事件,钩子可以获取任何键盘事件。
微博案例:
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
<style type="text/css">
div{
width:520px;
height:165px;
position:relative;
}
p{
font-size:12px;
}
textarea{
width:520px;
height:80px;
}
#s1{
text-align:left;
}
#s2{
position:absolute;
right:0;
}
textarea{
margin:0px;
padding:0px;
font-size:14px;
word-wrap:break-word;
line-height:18px;
overflow-y:auto;
overflow-x:hidden;
outline:none;
}
</style>
</head>
<body>
<div>
<p>
<span id="s1">有什么新鲜是想要告诉</span>
<span id="s2">男子住酒店枕头底下惊现万元现金 热门微博</span>
</p>
<textarea class="w_input" id="txt" title="微博输入框" name="" node-type="textE1" content="" ></textarea>
</div>
<script>
var txt=document.getElementById("txt");
var str;
txt.addEventListener("keyup",function(){
str=txt.value;
if(str.length>139){
document.getElementById("s2").innerHTML="已经超出了"+(str.length-140)+"个字";
}else{
document.getElementById("s2").innerHTML="您还可以输入"+(140-str.length)+"个字";
}
});
txt.addEventListener("focus",function(){
str=txt.value;
document.getElementById("s2").innerHTML="您还可以输入"+(140-str.length)+"个字";
});
txt.addEventListener("blur",function(){
document.getElementById("s2").innerHTML="男子住酒店枕头底下惊现万元现金 热门微博";
});
</script>
</body>
</html>
以下是一些键盘上的键对应的Code:以下是一些键盘上的键对应的Code:
键盘按键 对应的数码
backspace8tab9enter13shift16ctrl17alt18pause/break19caps lock20escape27page up33Space32page down34end35home36arrow left37arrow up38arrow right39arrow down40insert45delete46048149250351452553654755856957a65b66c67d68e69f70g71h72i73j74k75l76m77n78o79p80q81r82s83t84u85v86w87x88y89z90left window key91right window key92select key93numpad 096numpad 197numpad 298numpad 399numpad 4100numpad 5101numpad 6102numpad 7103numpad 8104numpad 9105multiply106add107subtract109decimal point110divide111f1112f2113f3114f4115f5116f6117f7118f8119f9120f10121f1
- js keyup、keypress和keydown事件 详解
- js keyup、keypress和keydown事件 详解
- js keyup、keypress和keydown事件 详解
- KeyDown,KeyPress 和KeyUp详解
- KeyDown,KeyPress和KeyUp详解
- keydown keypress keyup事件
- KeyDown,KeyPress 和 KeyUp
- KeyDown,KeyPress 和KeyUp
- 键盘事件keydown、keypress、keyup
- keyup 、keypress、keydown事件 onblur和onfocus事件
- js捕获键盘事件之keydown、keyup以及keypress
- 关于KeyPress,KeyDown和KeyUp
- c# KeyDown,KeyPress 和KeyUp
- C#,WinForm中的KeyDown,KeyPress 和KeyUp事件相关知识点
- KeyDown、KeyPress和KeyUp事件的区别与联系
- javascript KeyDown、KeyPress和KeyUp事件的区别与联系
- 键盘事件keypress 和 keydown、keyup 的用法与区别
- KeyPress、KeyDown、KeyUp事件&&KeyCode、KeyChar、KeyData
- LeetCode——044
- Spark性能相关参数配置 之 压缩和序列化相关
- Linux上使用iptables设置防火墙
- 硬件切换485电路
- IOS-UI设置字体属性
- js keyup、keypress和keydown事件 详解
- 陶哲轩实分析 3.3 节习题试解
- String.format()用法
- 【EJB系列】(四)——EJB基本内容总结
- 常用正则表达式
- this指针(待完善)
- Android View框架的layout机制
- 什么是软件需求?什么是功能需求?
- 堆优化 Dijstra单源最短路径算法 2(邻接表)