Fork me on GitHub

前端的小Demo——涉及keyCode

以下是我的代码:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>小效果</title>
<style>
    .type{width:32px;}
</style>
</head>

<body>
    <div>
        <button id="btn1">-</button>
        <input type="text" class="type"  id="txt">
        <button id="btn2">+</button>
    </div>
</body>
<script type="text/javascript" src="http://code.jquery.com/jquery.js"></script>
<script>
$(function(){
    var typeTxt;
    
    //只能输入大于1的数字   
$("#txt").keyup(function(){ $(this).val($(this).val().replace(/[^1-9.]/g,'')); }).bind("paste",function(){ $(this).val($(this).val().replace(/[^1-9.]/g,'')); }).css("ime-mode", "disabled");

//取值 $("#txt").change(function(){ typeTxt = $("#txt").val(); }) function up(){ typeTxt = $("#txt").val(); if(typeTxt>1){ typeTxt-=1; $("#txt").val(typeTxt);} else{ alert("数字不能小于1"); } } function down(){ typeTxt = $("#txt").val(); if(typeTxt>=1){ typeTxt++; $("#txt").val(typeTxt);} else{ alert("数字不能小于1");} } $("#txt").keyup(function(e){ if(e.keyCode == 38){ down(); } if(e.keyCode == 40) { up();} }); $("#btn1").click(function(){ up(); }); $("#btn2").click(function(){ down(); }); }) </script> </html>

用的是正则表达式的方法。

 

下面是主管的代码:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
<script>
window.onload=function(){
    var oInp1=document.getElementById("inp1");    
    var oInp2=document.getElementById("inp2");    
    var oInp3=document.getElementById("inp3");
    oInp1.onclick=function(){
        oInp2.value>1?oInp2.value-=1:alert("不能小于1");    
    };
    oInp3.onclick=function(){
        oInp2.value=parseInt(oInp2.value)+1;    
    };
    
    //大0  48
    //大9  57
    //小0  96
    //小9  105
    
    //退格 8
    oInp2.onkeydown=function(ev){
        var ev=ev||event;
        if(((ev.keyCode<48  || ev.keyCode>57) && (ev.keyCode!=8)) && (ev.keyCode<96  || ev.keyCode>105) ){    
            return false;
        }
    };
    oInp2.onkeyup=function(){
        if(this.value<1 && ev.keyCode!=8)
        {
            this.value=1    
        }    
    };
}
</script>
</head>

<body>
<input id="inp1" type="button" value="-">
<input id="inp2" style=" width:30px; text-align:center;" type="text" value="5">
<input id="inp3" type="button" value="+">
<h3>要求</h3>
<ul>
    <li>点击加减按钮可以使文本框内数字增减1但不能小于1</li>
    <li>文本框内只能输入数字,并且大小键盘都可以,可以用退格键删除文本框里的内容</li>
    <li>文本框内不可输入小于1的整数</li>
</ul>
</body>
</html>

再下面,是我不用表达式的方案,不过还有个小bug

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>小效果</title>
<style>
    .type{width:32px;}
</style>
</head>

<body>
    <div>
        <button id="btn1">-</button>
        <input type="text" class="type"  id="txt">
        <button id="btn2">+</button>
    </div>
</body>
<script type="text/javascript" src="http://code.jquery.com/jquery.js"></script>
<script>
$(function(){
    var typeTxt;
    
    //只能输入大于1的数字
    $("#txt").keyup(function(){
        if(isNaN($(this).val()) || parseInt($(this).val())<1){
            $(this).val("");    
        }
        else{typeTxt = $(this).val();    }
    });
       
    function up(){
        typeTxt = $("#txt").val();
        if(typeTxt>1){
            typeTxt-=1;
            $("#txt").val(typeTxt);
        }
        else{
            alert("数字不能小于1");    
        }    
    }
    function down(){
        typeTxt = $("#txt").val();
        if(typeTxt>=1){
            typeTxt++;
            $("#txt").val(typeTxt);
        }
        else{
            alert("数字不能小于1");    
        }
    }
    $("#txt").keyup(function(e){
        if(e.keyCode == 38)
        down();
        if(e.keyCode == 40)
        up();
    });
    
    $("#btn1").click(function(){
        up();
    });
    $("#btn2").click(function(){
        down();
    });
    
    
    
})
</script>
</html>

 

posted on 2014-08-01 11:32  雨为我停  阅读(359)  评论(0编辑  收藏  举报