号码验证的按键

问题描述 投票:5回答:5

我验证电话号码使用下面的代码的工作正常,但我让在第一次字符,而用户输入的值。我怎么能解决这个问题。 。 。 。

$('.Number').keypress(function () {
    $('.Number').keypress(function (event) {
        var keycode;

        keycode = event.keyCode ? event.keyCode : event.which;

        if (!(event.shiftKey == false && (keycode == 46 || keycode == 8 ||
                keycode == 37 ||keycode == 39 || (keycode >= 48 && keycode <= 57)))) {
            event.preventDefault();
        }
    });
});
javascript jquery asp.net-mvc jquery-ui
5个回答
4
投票

第一个字符是不受限制的,因为你嵌套keypress处理程序。尝试这个:

$('.Number').keypress(function (event) {
    var keycode = event.which;
    if (!(event.shiftKey == false && (keycode == 46 || keycode == 8 || keycode == 37 || keycode == 39 || (keycode >= 48 && keycode <= 57)))) {
        event.preventDefault();
    }
});

3
投票

尝试

$('.Number').keyup(function (event) {
    var keycode = event.which;
    if (!(event.shiftKey == false && (keycode == 46 || keycode == 8 || keycode == 37 || keycode == 39 || (keycode >= 48 && keycode <= 57)))) {
        event.preventDefault();
    }
});

1
投票

这里是将验证输入的功能。如果值是一个数字,否则为false它将返回true。数字则charCode 48 - 57。此功能还允许所有的控制字符返回true。 (<32)

function isNumber(evt)
{
   evt = (evt) ? evt : window.event;
   var charCode = (evt.which) ? evt.which : evt.keyCode;
   if (charCode > 32 && (charCode < 48 || charCode > 57)) {
      return false;
    }
    return true;
}

Here is a chart of the codes.


0
投票
<html>
<head>
<title>number validation</title>
<script>
    function checkNumber(check)
    {   
        var a = document.getElementById("txt_contact_no").value;
        //var x=check.which;
        //var x = a.charCode;
        var x = a.keyCode;
        if(!(a >= 48 || a <= 57))
        {
            alert("enter only numbers");
            return false;
        }       
        else if(a=="" || a==null)
        {
            alert("field is blank");
            return false;
        }
// if no is more then the value 
        /*else if (a.length <= 9)
        {
            alert("enter minimum 10 characters");
            return false;
        }*/
        alert("done");
        return true;        
    }
</script>
</script>
</head>
<body>
<table>
<form name=form1 method=post action="#">
    <tr>
        <td>
        <b>Subjects</b><input type="text" name="contact_no" id="txt_contact_no" onblur="checkNumber(this)"> 
        </td>
    </tr>
    <tr>
        <td><p id="p1"></p></td>
    </tr>
</form>
</table>
</body>

0
投票

这是按键响应次数活动最简单的办法:

 $(document).ready(function(){ 			
    $(".Number").keypress(function(event){
        var keycode = event.which;
        if (!(keycode >= 48 && keycode <= 57)) {
            event.preventDefault();
        }
    });
 });
© www.soinside.com 2019 - 2024. All rights reserved.