js keyup、keypress和keydown事件 详解

来源:互联网 发布:淘宝免费推广的方法 编辑:程序博客网 时间:2024/05/01 15:16

js keyup、keypress和keydown事件 详解

js keyup、keypress和keydown事件  详解

js keyup、keypress和keydown事件都是有关于键盘的事件

当一个按键被pressed 或released在每一个现代浏览器中,都可能有三种客户端事件。

  1. keydown event
  2. keypress event
  3. 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(){ ...}

 

注意:

  1. KeyDown触发后,不一定触发KeyUp,当KeyDown 按下后,拖动鼠标,那么将不会触发KeyUp事件。
  2. KeyPress主要用来捕获数字(注意:包括Shift+数字的符号)、字母(注意:包括大小写)、小键盘等除了F1-12、SHIFT、Alt、Ctrl、Insert、Home、PgUp、Delete、End、PgDn、ScrollLock、Pause、NumLock、{菜单键}、{开始键}和方向键外的ANSI字符
  3. KeyDown 和KeyUp 通常可以捕获键盘除了PrScrn所有按键(这里不讨论特殊键盘的特殊键)
  4. KeyPress 只能捕获单个字符
  5. KeyDown 和KeyUp 可以捕获组合键。
  6. KeyPress 可以捕获单个字符的大小写
  7. KeyDown和KeyUp 对于单个字符捕获的KeyValue 都是一个值,也就是不能判断单个字符的大小写。
  8. KeyPress 不区分小键盘和主键盘的数字字符。
  9. KeyDown 和KeyUp 区分小键盘和主键盘的数字字符。
  10. 其中PrScrn 按键KeyPress、KeyDown和KeyUp 都不能捕获。
  11. 在使用键盘的时候,通常会使用到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());
    }
    }
  12. 捕获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 point110divide111f1112f2113f3114f4115f5116f6117f7118f8119f9120f10121

f1

0 0
原创粉丝点击