【问题标题】:How can I make the HTML5 number field display trailing zeroes?如何使 HTML5 数字字段显示尾随零?
【发布时间】:2011-12-09 02:04:29
【问题描述】:

我有一个字段:

<input type='number' />

我想在0.50 不“更正”为0.5 的情况下打卡,所以它会显示0.50

【问题讨论】:

  • 感谢 Paul 的编辑,标题更加简洁。

标签: html input numbers decimal field


【解决方案1】:

我将 on('change') 事件附加到您想要尾随 0 的输入

$('.number-input').on('change', function(){
    $(this).val(parseFloat($(this).val()).toFixed(2));
});

它只是获取值,将其转换为浮点数,将其呈现为小数位数的字符串,然后将其作为值放回。

【讨论】:

  • 这是一个很好的解决方案,甚至不应该存在的问题。
  • 可以在 FF 中确认,它仍然“更正”该值并丢弃尾随零。
【解决方案2】:

我对此进行了一些尝试,并查看了规范。它说它必须是一个有效的浮点数。它给出的definition of a valid floating point number中有一句话引起了我的注意:

数字 n 作为浮点数的最佳表示是 通过应用 JavaScript 运算符 ToString 获得的字符串 n.

这意味着格式将始终与评估数字是一致的,然后在该数字上使用 JavaScript 的 toString。所以没有尾随的 0。

因此,您将不得不求助于 JavaScript。这并不简单,因为document.getElementById('numInput').value = '0.50'; 仍然被更正为0.5,因此验证不会在onchange 触发,默认操作可以被阻止,而是在内部触发。

这是我能想到的最好的解决方案......它有点小技巧,需要进行一些调整以提高稳健性,但希望它能满足您的需求:

var numInput = document.getElementById('numInput');
numInput.addEventListener('keypress', function () {
    this.setAttribute('type', 'text');
});
numInput.addEventListener('click', function () {
    this.setAttribute('type', 'number');
});

因此,如果用户想通过键入来输入数字,它会将输入类型切换为文本,但当他们单击它时,它会将其转换回数字。

如果无论用户输入什么内容,您总是想要尾随的 0,那么您可以这样做:

var numInput = document.getElementById('numInput');
numInput.addEventListener('blur', function () {
    if (this.value === '') {
        return;
    }
    this.setAttribute('type', 'text');
    if (this.value.indexOf('.') === -1) {
        this.value = this.value + '.00';
    }
    while (this.value.indexOf('.') > this.value.length - 3) {
        this.value = this.value + '0';
    }
});
numInput.addEventListener('focus', function () {
    this.setAttribute('type', 'number');
});

编辑:我认为第二种解决方案更符合用户的期望,但这意味着如果用户输入0.5,它将被强制为0.50,所以这取决于如果这就是你想要的。

【讨论】:

  • 这是一个非常聪明的解决方法,方法是更正小数并在文本和数字字段之间切换。谢谢!
  • 很高兴你喜欢它。这是 IMO 在 HTML5 规范中的一个缺点,所以希望有人能意识到这一点并在未来的某个时候修复它。
  • 很好的解决方案。我将它扩展了一点,只影响指定的输入,并且还使用了“更改”事件,即使在您按下输入按钮时,它也会保留尾随零。不知道为什么它不适用于普通的 JS 'onchange',所以我在 JQuery 中做到了。仅在 Chrome 上测试:$('input.float').each(function(index) { $(this).change(function(event) { if (this.value === '') { return; } if (this.value.indexOf('.') === -1) { this.value = this.value + '.00'; } while (this.value.indexOf('.') &gt; this.value.length - 3) { this.value = this.value + '0'; } }); });
  • 这不起作用(至少在 FF 50 中),因为更改“类型”属性会触发模糊。因此,在您的代码中,焦点将类型更改为数字,这会触发模糊,这会将类型更改为文本,这会触发另一个模糊 - 您永远无法专注于元素。
  • @Coder 在我编写它时,它可以在 Chrome 和 Firefox 的任何版本中运行。我想我们一直在寻找一个好的解决方案,直到有人决定实现 format 属性或类似属性。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多