html5数字在线处理,如何使HTML5数字字段显示尾随零?

这篇博客探讨了如何在JavaScript中确保输入的浮点数始终保留尾随零,即使在用户交互中。作者提出了一种方法,通过监听键盘事件和输入字段的焦点及模糊事件来切换输入类型,从而在用户离开输入框时自动添加尾随零。这种方法可能需要进一步的优化以提高鲁棒性,但提供了一个解决此问题的思路。
摘要由CSDN通过智能技术生成

小编典典

我对此进行了一些尝试,并查看了规格。它说它必须是一个有效的浮点数。在给出的有效浮点数的定义中有一句话引起了我的注意:

数字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,因此这取决于您是否要这样做。

2020-05-10

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值