我使用這個jQuery代碼,只允許在輸入文本字段中輸入數字。如何僅使用jQuery在輸入文本字段中允許數字(即使在複製粘貼時)?
jQuery(document).ready(function() {
jQuery('.only_numbers').keydown(function (e) {
// Allow: backspace, delete, tab, escape, enter and .
if (jQuery.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();
}
});
});
這工作正常,除了一個小問題。它不允許在該領域粘貼任何東西。我如何允許用戶在字段中粘貼字符串,只要字符串包含所有數字字符?
此外,如果我可以對輸入文本字段只允許使用字母表做同樣的操作,那將會很棒。
我不想使用,因爲在瀏覽器的兼容性,造型和製作表單字段粘性問題'類型=「數字」'限制其他鍵。 – user1543784
但它在所有現代瀏覽器中得到廣泛支持。 http://caniuse.com/#feat=input-number – Manish
檢查我更新的答案它使用'type = text'驗證這兩種類型,並且支持IE和Firefox以及其他瀏覽器。 – Manish