三个键盘事件的区别:

Posted yjzs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了三个键盘事件的区别:相关的知识,希望对你有一定的参考价值。

onkeyup:

       这个事件在用户按下并放开任何字母数字键时发生。系统按钮(例如,箭头键和功能键)无法得到识别。 

onkeydown:

       这个事件在用户放开任何先前按下的键盘键时发生。

onkeypress :

      这个事件在用户按下任何键盘键(包括系统按钮,如箭头键和功能键)时发生。 

三者之间的执行顺序:

     当按下回车时,焦点从文本框移到按钮上。如果把它换成“onkeypress”,焦点不会转移,也不会失去。但是如果换成“onkeyup”,则失去焦点,页面重新载入。 
测试发现onkeydown 事件最先执行,其次是onkeypress,最后是onkeyup;onkeydown 和onkeypress会影响onkeyup的执行。三个事件同事在的话,都是alert的话,只会弹出2个alert,up事件的alert不会弹出。 

三者之间的不同点:

       三者在事件的响应上还有一点不同,就是onkeydown 、onkeypress事件响应的时候输入的字符并没有被系统接受,而响应onkeyup的时候,输入流已经被系统接受。由于onkeydown 比onkeypress先执行,再根据上面的例子可以知道,onkeydown 触发的时候输入流正要进入系统,也就是说onkeydown 事件一完,输入流就进入了系统,无法改变。所以通过onkeydown 事件可以改变用户是按了哪个键;而onkeypress事件则是在输入流进入系统后触发的,但输入流暂未被系统处理,此时已经不能改变输入流了;onkeyup则是输入流被系统处理后发生的。

以上是关于三个键盘事件的区别:的主要内容,如果未能解决你的问题,请参考以下文章

Android 键盘事件触发以及监听

js键盘事件的使用

javascript事件相关3

pyHook无法监听键盘事件?

Vue中监听键盘事件

事件委托与键盘事件