KeyPress 和KeyDown 、KeyPress之间的区别

KeyPress 和KeyDown 、KeyPress之间的区别一 键事件按下列顺序发生 nbsp KeyDownKeyPr nbsp 二 KeyDown 触发后 不一定触发 KeyUp 当 KeyDown 按下后 拖动鼠标 那么将不会触发 KeyUp 事件 nbsp 三 定义 KeyDown 在控件有焦点的情况下按下键时发生 KeyPress 在控件有焦点的情况下按下键时发生 下面会说和 KeyDo

虽然从字面理解, KeyDown是按下一个键的意思, 但实际上二者的根本区别是, 系统由KeyDown返回键盘的代码, 然后由TranslateMessage函数翻译成成字符, 由KeyPress返回字符值. 因此在KeyDown中返回的是键盘的代码, 而KeyPress返回的是ASCII字符. 所以根据你的目的, 如果只想读取字符, 用KeyPress, 如果想读各键的状态, 用KeyDown. 



keydown:用户在键盘上按下某按键是发生。一直按着某按键则会不断触发(opera浏览器除外)。
keypress:用户按下一个按键,并产生一个字符时发生(也就是不管类似shift、alt、ctrl之类的键,就是说用户按了一个能在屏幕上输出字符的按键keypress事件才会触发)。一直按着某按键则会不断触发。
keyup:用户释放某一个按键是触发。






定义和用法

完整的 key press 过程分为两个部分:1. 按键被按下;2. 按键被松开。

当按钮被按下时,发生 keydown 事件。

keydown() 方法触发 keydown 事件,或规定当发生 keydown 事件时运行的函数。

 

[html]  view plain copy

  1. <html>  
  2. <head>  
  3. <script type=“text/javascript” src=“/jquery/jquery.js”>
    script>  
  4. <script type=“text/javascript”>  
  5. $(document).ready(function(){  
  6.   $(“input”).keydown(function(){  
  7.     $(“input”).css(“background-color”,”#FFFFCC”);  
  8.   });  
  9.   $(“input”).keyup(function(){  
  10.     $(“input”).css(“background-color”,”#D6D6FF”);  
  11.   });  
  12. });  

  13. script>  

  14. head>  
  15. <body>  
  16. Enter your name: <input type=“text” />  
  17. <p>当发生 keydown 和 keyup 事件时,输入域会改变颜色。请试着在其中输入内容。
    p>  

  18. body>  

  19. html>  

中所周知,jquery封装了很多事件交互方法,这里讲到的问题在原生js中也是有的。

keyup是在用户将按键抬起的时候才会触发的,属于整个按键过程中的最后阶段,所以有其特定的用处,就是在左侧输入,右侧同步显示的过程中很有用处。典型的例子就是邮件编辑预览的应用。

[html]  view plain copy

  1. <html xmlns=“http://www.w3.org/1999/xhtml”>  
  2. <head>  
  3.     <title>无标题页
    title>  
  4.   
  5.     <script src=“JS/jquery-1.4.2.js” type=“text/javascript”>
    script>  
  6.   
  7.     <script type=“text/javascript”>  
  8.         $(function() {  
  9.             $(‘#t1’).live(‘keyup’, function() {  
  10.                 $(‘#v1’).text($(this).val());  
  11.             });  
  12.             $(‘#t2’).live(‘keydown’, function() {  
  13.                 $(‘#v2’).text($(this).val());  
  14.             });  
  15.             $(‘#t3’).live(‘keypress’, function() {  
  16.                 $(‘#v3’).text($(this).val());  
  17.             });  
  18.         });      
  19.     
    script>  
  20.   

  21. head>  
  22. <body>  
  23.     <textarea id=“t1”>
    textarea>  
  24.     <div id=“v1”>  
  25.     
    div>  
  26.     <textarea id=“t2”>
    textarea>  
  27.     <div id=“v2”>  
  28.     
    div>  
  29.     <textarea id=“t3”>
    textarea>  
  30.     <div id=“v3”>  
  31.     
    div>  

  32. body>  

  33. html>  

这里分别应用了三种事件,其中t1能够完整的同步到v1中,而keypress和keydown总是少最后一个字符,这样就说明了这三种事件触发的小小区别,keydown是在按下时触发,不能得到最后的输入结果,keypress也是一样。

例如:keydown绑定文本框,每次点击触发事件,在获取文本框的值,总是打印上次操作时文本框的内容,

 

 keydown与keypress更适用于通过键盘控制页面类功能的实现。

获取键盘点击的键位:

 

[html]  view plain copy

  1. <html>  
  2. <head>  
  3. <script type=“text/javascript” src=“/jquery/jquery.js”>
    script>  
  4. <script type=“text/javascript”>  
  5. $(document).ready(function(){  
  6.   $(“input”).keydown(function(event){   
  7.     $(“div”).html(“Key: ” + event.which);  
  8.   });  
  9. });  

  10. script>  

  11. head>  
  12. <body>  
  13.   
  14. 请随意键入一些字符:<input type=“text” />  
  15. <p>当您在上面的框中键入文本时,下面的 div 会显示键位序号。
    p>  
  16. <div />  
  17.   

  18. body>  

  19. html>  



版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/215362.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月18日 下午2:05
下一篇 2026年3月18日 下午2:06


相关推荐

  • accept 函数_case when函数

    accept 函数_case when函数2.关于AcceptEx  使用此函数时,要包含头文:Mswsock.h,同时要链接:Mswsock.lib。可在源程序中加入下面的语句,这样在编译时,将自动链接Mswsock.lib。  #pragmacomment(lib,”Mswsock.lib”)    下面是使用AcceptEx函数的示例代码:  #defineSTRICT  #define_WIN32_WINNT0x050

    2026年4月18日
    7
  • 给空白包签名MD5/认领应用/所有权认证

    给空白包签名MD5/认领应用/所有权认证

    2021年10月1日
    97
  • 电阻电容电感的常用标注方法(手机电容和电阻的区分)

    认识电容及电容电阻的标注   一、认识电容及电容的标注①电容的功能和表示方法。由两个金属极,中间夹有绝缘介质构成。电容的特性主要是隔直流通交流,因此多用于级间耦合、滤波、去耦、旁路及信号调谐。电容在电路中用“C”加数字表示,比如C8,表示在电路中编号为8的电容。②电容的分类。电容按介质不同分为:气体介质电容,液体介质电容,无机固体介质电容,有机固体介质电容电解电容。按极性分为:有极性电容和无极性电

    2022年4月12日
    140
  • MAX31865和PT100 PT1000的小白避坑攻略

    MAX31865和PT100 PT1000的小白避坑攻略关于例程和资料已上传,大家可以免费下载:https://download.csdn.net/download/winux123/12106121百度下载链接:https://pan.baidu.com/s/1gU_k_XRmGoJ4MORQoysuEQPT100/PT1000两线硬件接法:PT100/PT1000两线程序修改两处:PT100/PT1000三线硬…

    2022年6月15日
    27
  • CACL联赛第一赛季第一轮比赛排名公布!

    CACL联赛第一赛季第一轮比赛排名公布!亲爱的同学们,CACL联赛第一赛季第一轮,“波士顿房价预测”比赛结束啦!本轮比赛共计31支队伍提交了有效结果。一、比赛结果第一名:浙江大学AI俱乐部第二名:中国海洋大学智能数据分析俱乐部第三名:重庆邮电大学人工智能协会恭喜同学们获得好名次,也非常感谢同学们的热情参与。排名前五的结果代码已在T-CCP社区公布。点击查看>>>另外排名前五的战队会颁发获奖证书,第六名及以后…

    2025年6月26日
    3
  • 数据库之六大范式详解

    数据库之六大范式详解数据库六大范式详解关系数据库中的关系满足一定要求的 满足不同程度要求的为不同的范式 满足最低要求的叫第一范式 简称 1NF 在第一范式的基础上满足进一步要求的称为第二范式 简称 2NF 其余范式以此类推 对于各种范式之间有如下关系 如下图所示 1 第一范式 1NF 定义 属于第一范式关系的所有属性都不可再分 即数据项不可分 理解 第一范式强调数据表的原子性 是其他范式的

    2026年3月19日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号