だから私はフォームに取り組んでおり、小数点の後に小数点以下5桁を許可するフィールドがあります。ただし、これを .focus() および .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 でした。