如何在文本框中输入后编辑十进制数

时间:2018-02-28 09:53:43

标签: javascript jquery event-handling

在我输入xyxyx.xy之类的十进制数字后,我无法编辑或重新输入数字,例如:45682.23在文本框中。

在Firefox中,我无法在输入后编辑输入的值。在Chrome中它似乎可以正常工作

有人在我的代码中发现了问题吗?

https://jsfiddle.net/s4ywLapp/56/

$('#decimalNumber').keypress(function(event) {

  if ((event.which != 46 || $(this).val().indexOf('.') != -1) && (event.which < 48 || event.which > 57)) {

    if ((event.which != 46 || $(this).val().indexOf('.') != -1)) {

    }
    event.preventDefault();
  }
  if (this.value.indexOf(".") > -1 && (this.value.split('.')[1].length > 1)) {
    //alert('Two numbers only allowed after decimal point');
    event.preventDefault();
  }

});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="text" id="decimalNumber" />

1 个答案:

答案 0 :(得分:0)

您可以包含以下条件以允许编辑整数位

//alert('Two numbers only allowed after decimal point');
    if(this.selectionStart > this.value.length - this.value.split('.')[1].length){
          event.preventDefault();

    }

然而,它仍然很脏。你应该在小数点后2位数时右键修剪按键上的十进制数字。