-1

我动态添加了一些输入字段(都有一个“addToQuantityTotal_1”类名)并且希望用户只能在里面输入数字。

所以我使用“on”关键字(因为这是它与页面完成加载后创建的元素一起工作的唯一方法)并且一切正常,除了:“event.preventDefault()”

它标识用户按下非数字键,但仍将其添加到输入字段。

$('body').on('keydown', 'input.addToQuantityTotal_1', function() {
    alert("keyCode = " + event.keyCode);
    // Allow: backspace, delete, tab, escape, and enter
    if ( event.keyCode == 46 || event.keyCode == 8 || event.keyCode == 9 || event.keyCode == 27 || event.keyCode == 13 || 
         // Allow: Ctrl+A
        (event.keyCode == 65 && event.ctrlKey === true) || 
         // Allow: home, end, left, right
        (event.keyCode >= 35 && event.keyCode <= 39)) {
             // let it happen, don't do anything
             return;
    }
    else {
        // Ensure that it is a number and stop the keypress
        if (event.shiftKey || (event.keyCode < 48 || event.keyCode > 57) && (event.keyCode < 96 || event.keyCode > 105 )) {
            alert("this is NOT a number!");
            event.preventDefault(); 
        }   
    }
});

任何帮助将不胜感激,谢谢!

4

1 回答 1

5

event没有定义。它应该是function(event) {...

于 2013-08-06T09:23:56.503 回答