测试界面如下:
测试代码如下:
html代码:
<input type="text" onkeydown="downEvent()" onkeypress="pressEvent()" onkeyup="upEvent()"></br></br>
<input type="label" id="downEvent"></br>
<input type="label" id="pressEvent"></br>
<input type="label" id="upEvent"></br>
js代码:
function downEvent(){
document.getElementById("downEvent").value="downEvent";
//alert("downEvent is doing");
}
function pressEvent(){
document.getElementById("pressEvent").value="pressEvent";
//alert("pressEvent is doing");
}
function upEvent(){
document.getElementById("upEvent").value="upEvent";
//alert("upEvent is doing");
}
</script>
结果:
触发事件的前提:交点在输入框控件上
特殊情况:
*三个事件都触发Enter键
*三个事件都不触发Fn键
*三个事件同时存在时,alert只会弹出onkeydown和onkeypress
*只能在onkeydown事件中改变输入字符,如:event.keyCode=65;
*汉字拼音输入的过程只触发onkeydown和onkeyup,如下:
三者区别:
执行顺序:onkeydown–>onkeypress–>onkeyup
1. onkeydown:键盘一按下就触发的事件,键盘上任意键都会触发onkeydown()事件。
2. onkeypress:键盘一按下就触发的事件,同onkeydown(除去功能键,如:Esc,Shift,Ctrl..)
3. onkeyup:按键一松开就触发的事件。键盘上任意键都会触发onkeyup()事件。
版权声明:本文为qq_34338787原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。