<input id='nb' name="nb" type="number" placeholder="Number"/>
如果只有数字,则jQuery.val()返回值,如果有任何字母则返回空值。
Chrome显示输入数字箭头(并且它们有效),但我也可以输入字母。奇怪的是
关于mozilla和IE8的BTW它变成了正常的输入文本(猜我有一个老的mozilla)
有什么想法吗?无法在jQuery doc上找到任何特定于.val()
的数字输入的内容答案 0 :(得分:1)
建议使用input type="text"
代替HTML5输入input type="number"
:
//HTML
<input id="inp" type="text" />
//JAVASCRIPT (JQUERY NEEDED)
function onlyNumbers(evt) {
// SOME OPTIONS LIKE ENTER, BACKSPACE, HOME, END, ARROWS, ETC.
var arrayExceptions = [8, 13, 16, 17, 18, 20, 27, 35, 36, 37,
38, 39, 40, 45, 46, 144];
if ((evt.keyCode < 48 || evt.keyCode > 57) &&
(evt.keyCode < 96 || evt.keyCode > 106) && // NUMPAD
$.inArray(evt.keyCode, arrayExceptions) === -1) {
return false;
}
}
$('#inp').on('keydown', onlyNumbers);
//JAVASCRIPT (WITHOUT JQUERY)
function inArray(value, arr) {
for(var i = 0; i < arr.length; i++) {
if (value === arr[i]) {
return i;
}
}
return -1;
}
function onlyNumbers(evt) {
// SOME OPTIONS LIKE ENTER, BACKSPACE, HOME, END, ARROWS, ETC.
var arrayExceptions = [8, 13, 16, 17, 18, 20, 27, 35, 36, 37,
38, 39, 40, 45, 46, 144];
if ((evt.keyCode < 48 || evt.keyCode > 57) &&
(evt.keyCode < 96 || evt.keyCode > 106) && // NUMPAD
inArray(evt.keyCode, arrayExceptions) === -1) {
return false;
}
}
document.getElementById('inp').onkeydown = onlyNumbers;
正如我在评论中所说,直到HTML5成为我们可以正常使用的标准网络语言,我更喜欢使用它。
使用jQuery实答案 1 :(得分:0)
如果您只想从输入中获取数字,那么您需要使用正则表达式。最初使用$(your_element).val()从输入中获取值,然后使用正则表达式。
Here是一个正在运行的例子。希望它有所帮助。