色婷婷狠狠18禁久久YY,CHINESE性内射高清国产,国产女人18毛片水真多1,国产AV在线观看

jquery input 正整數

方一強2年前8瀏覽0評論

jQuery是一個非常流行的JavaScript庫,在網頁開發中廣泛應用。其中,input輸入框是常見的網頁元素之一。在某些情況下,我們需要限制input輸入框只能輸入正整數,而不是允許任何字符都可以輸入。下面我們就來看看怎么使用jQuery來實現這個功能。

首先,我們需要給輸入框綁定onkeydown事件,這個事件會在用戶按下鍵盤上的任何一個鍵時觸發。在事件中,我們需要判斷輸入的字符是否為數字,如果不是就取消事件執行,這樣就能防止不合法的字符輸入。

$('input').on('keydown', function (event) {  
// 如果按下的不是數字鍵或小數點鍵或backspace鍵,就禁止輸入  
if (!((event.keyCode >= 48 && event.keyCode<= 57) ||   
(event.keyCode >= 96 && event.keyCode<= 105) ||    
event.keyCode == 190 || event.keyCode == 8)) {    
event.preventDefault();    
}    
});

上面的代碼中,keyup事件碼值為48~57和96~105表示數字鍵,190表示小數點鍵,8表示backspace鍵,其他鍵都不能輸入。

其次,我們還需要防止用戶復制、粘貼非數字字符的行為。同樣地,我們可以使用onpaste和oncopy事件來實現防止非數字復制和粘貼,在事件中把非數字剔除掉即可。

$('input').on('paste', function (event) {  
// 獲取粘貼板數據  
var clipboardData = event.clipboardData || window.clipboardData;  
var pastedData = clipboardData.getData('text');  
// 非數字的正則表達式  
var reg = /[^\d]/g;  
if (reg.test(pastedData)) {  
// 把非數字剔除掉  
event.preventDefault();  
$(this).val($(this).val().replace(reg, ''));  
}  
});  
$('input').on('copy', function (event) {  
// 獲取輸入框內數字的正則表達式  
var reg = /\d/g;  
if (!reg.test(event.originalEvent.clipboardData.getData('text'))) {  
// 如果復制的字符串非數字,就取消復制事件  
event.preventDefault();  
}  
});

最后,我們還需要判斷輸入的數字是否為正整數,而不是負數或小數。同樣地,我們可以在鍵盤輸入結束后,判斷輸入框內的數字是否為正整數,如果不是,就清空輸入框內的內容。

$('input').on('blur', function () {  
var val = $(this).val();  
if (!/^[1-9]\d*$/.test(val)) {  
// 如果不是正整數,就清空輸入框  
$(this).val('');  
}  
});

至此,限制input輸入正整數的jQuery代碼就完成了。需要注意的是,我們的代碼只是前端代碼,為了更好地防止用戶惡意輸入或操作,還需要在后端對輸入值進行操作和判斷。