所以我正在处理一个表单和一个字段,我应该在小数点分隔符后允许 5 个小数。但是,我还必须在 .focus() 和 . blur() 事件,它可以工作。但是,当我单击 elsewere 以在我的输入字段中按我想要的格式设置我的值时,从我的 5 位小数中删除了我的最后 2 位。例如:我输入 78676,56569,重新返回 78.676,565 如何更改代码以使其不删除我的最后 2 位小数?这是我所拥有的:
function fiveDecimals(event) {
var $txtBox = $(this);
var key = window.event ? event.keyCode : event.which;
if (event.keyCode == 8 || event.keyCode == 9 || event.keyCode == 37 || event.keyCode == 39) {
return true;
} else if ( key < 44 || key > 57 && event.keyCode != 44) {
event.preventDefault();
}else {
var len = $txtBox.val().length;
var index = $txtBox.val().indexOf(',');
if (index > 0 && event.keyCode == 44) {
return false;
} //prevent if already comma
if (index > 0) {
var charAfterdot = (len + 1) - index;
//allows only 5 decimals
if (charAfterdot > 6) {
return false;
}
}
}
return $txtBox;
};
var
dec_separator = (0.1).toLocaleString().substr(1,1), // Get decimal separator
dec_xsanitize = new RegExp('[' + dec_separator + ']', 'g'), // Get thousands separator
tho_separator = (1000).toLocaleString().substr(1,1),
tho_xcleaner = new RegExp('[' + tho_separator + ']', 'g');
$('#float2')
.on("focus", function ()
{
this.value = this.value.replace( tho_xcleaner, '' );
})
.on("blur", function ()
{// Clean thousands separator and change decimal separator
var number = parseFloat(this.value.replace( tho_xcleaner, '' ).replace( dec_xsanitize, '.' ));
this.value = isNaN(number) ? '0': number.toLocaleString();
});
这是 Jsfiddle:http: //jsfiddle.net/Daria90/zuxu5tva/
请注意,我的小数分隔符是在 DE 系统上设置的,所以在英文键盘上它可能是一个句点,keyCode 是 46。我的是 44。