javascript - Jquery 函数无法正确阻止输入字母

标签 javascript jquery

我有一个名为dateField的类,我将其分配给采用日期的输入。它应该阻止插入字母,如果用户尝试输入字母,它应该阻止该操作。它进入 if 触发 e.preventDetaul() 但它实际上并没有停止操作。

$(document).off('keyup', '.dateField');
$(document).on('keyup', '.dateField', function(e){
    $(this).attr('maxlength', '10');

    if ($.inArray(e.keyCode, [46, 8, 9, 27, 13, 110, 190]) !== -1 ||
         // Allow: Ctrl+A, Command+A
        (e.keyCode === 65 && (e.ctrlKey === true || e.metaKey === true)) ||
         // Allow: home, end, left, right, down, up
        (e.keyCode >= 35 && e.keyCode <= 40)) {
             // let it happen, don't do anything
             return;
    }
    // Ensure that it is a number and stop the keypress
    if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) {
        e.preventDefault();
    }

    var value=$(this).val();

    if(value.length==2||value.length==5){
        $(this).val($(this).val()+'/');
    }

    if (value.length > 9) {
        var comp = $(this).val().split("/");
        var m = parseInt(comp[0], 10);
        var d = parseInt(comp[1], 10);
        var y = parseInt(comp[2], 10);

        var date = new Date(y,m-1,d);

        if (date.getFullYear() == y && date.getMonth() + 1 == m && date.getDate() == d) {
          $(this).removeClass('fail');
        } else {
          $(this).addClass('fail');
        }
    }

    if(e.keyCode == 13 || e.which == 13){
        e.preventDefault();

        if($(this).hasClass('tcal')){
            var date = $(this).val().split("/");
            var m = parseInt(date[0], 10),
            d = parseInt(date[1], 10),
            y = parseInt(date[2], 10);

            if(new Date(y, m - 1, d)!='Invalid Date'){
                //alert( new Date(y, m - 1, d));
                $('.date-manage').mouseleave();
                $('.date.sub-title').html($('#date-between').val()+' to '+$('#date-and').val());

                //$(".box-date input").unbind("blur");
            }
        }

        $('.date-animation').stop();
        $('.date-animation').animate({height: 0}, 500, 'easeOutQuart');
    }
});

enter image description here

最佳答案

您是否尝试过其他事件,例如 keydown?也许 keyup 太晚了,字符已经插入到输入中。

关于javascript - Jquery 函数无法正确阻止输入字母,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46791514/

相关文章:

php - 如何使用 jQuery 在模式弹出窗口中传递值

javascript - 如何在 Jquery Mobile 1.4.5 中刷新新的 Div 内容

javascript - Angular Controller 检查服务 promise 以更新 View

javascript - 随着时间的推移,Ajax 繁重的 JS 应用程序使用过多的内存

javascript - 不同方式选择DOM Element会带来不同的结果

JavaScript:数组声明上的 If 语句

jQuery UI 如何: Click a button and send the whole sortable list to another tab

javascript - d3 在 setInterval 上闪烁线

javascript - 如何在 JavaScript 中使用 JIRA REST API 的基本身份验证?

javascript - 如果 text-indent 设置为百分比值,它用于计算的宽度是多少?