2013-08-06 7 views
-1

Я добавляю несколько полей ввода динамически (все они имеют имя класса «addToQuantityTotal_1») и хотят, чтобы пользователь мог только вводить числа внутри.JQuery: «event.preventDefault()» не будет работать для динамически создаваемых элементов ...?

Так я использую «на» ключевое слово (потому что это единственный способ, он работал с элементами, которые я создал после страницы готовой загрузки) и все работает отлично, за исключением: «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(); 
     } 
    } 
}); 

Любая помощь будет принята с благодарностью, спасибо!

+1

Вы пропустите параметр 'event' в параметрах функции' $ ('body'). On ('keydown', 'input.addToQuantityTotal_1', function (event) {' – Daniele

+1

Что касается проверки вашей консоли в следующий раз –

+0

Как он идентифицирует нечисловые нажатия клавиш без параметра события? – Archer

ответ

5

event не определен. Он должен быть function(event) {...

+0

Спасибо Daniel & slash197, Вы оба помогли :) – spelltox

Смежные вопросы