用鼠标选择时,我无法编辑文本字段。
我尝试在jquery中使用keypress事件来限制小数点后两个小数位。
$('.decimal').keypress(function (e) {
var character = String.fromCharCode(e.keyCode)
var newValue = this.value + character;
if (isNaN(newValue) || parseFloat(newValue) * 100 % 1 > 0) {
e.preventDefault();
return false;
}
});
在这里,当我用鼠标在薪金字段中选择文本时,我在加载时遇到了问题,我无法编辑该字段,但是当触发按键事件时,它工作正常。
$(function () {
$('#name').bind('paste', function () {
var self = this;
setTimeout(function () {
if (!/^[a-zA-Z]+$/.test($(self).val())) $(self).val('');
}, 0);
});
$('#salary').bind('paste', function () {
var self = this;
setTimeout(function () {
if (!/^\d*(\.\d{1,2})+$/.test($(self).val())) $(self).val('');
}, 0);
});
/*$('.decimal').keyup(function () {
var val = $(this).val();
if (isNaN(val)) {
val = val.replace(/[^0-9]./{2,2}/g,'');
if(val.split('.').length>2)
val =val.replace(/\. + $ / , "");
}
$(this).val(val);
});*/
$('.decimal').keypress(function (e) {
var character = String.fromCharCode(e.keyCode)
var newValue = this.value + character;
if (isNaN(newValue) || parseFloat(newValue) * 100 % 1 > 0) {
e.preventDefault();
return false;
}
});
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<b>Name</b>
<input type="text" id="name" />
<br/>
<b>Salary</b>
<input type="text" id="salary" class="decimal" />