首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >输入属性type="number“在IE11中不工作。我怎么才能避开这一切?

输入属性type="number“在IE11中不工作。我怎么才能避开这一切?
EN

Stack Overflow用户
提问于 2021-06-20 15:52:20
回答 2查看 88关注 0票数 0

我有一个简单的表单,其中一个输入字段的类型是数字

代码语言:javascript
复制
<input type="number" step="0.5" required/>

这在大多数浏览器中都能使用。然而,在Internet 11上,type="number"的验证是有缺陷的。它只允许数值,但是在输入一个数字之后,验证似乎停止工作。

例如,在大多数浏览器中,type="number"的验证工作如下所示:

value

  • example!50

  • 50是有效的
  • 50是无效的是无效的值。

而在中,它的工作方式如下:

value

  • example!50

  • 50是有效的
  • 50是无效的是有效值。

我如何确保在的输入字段中只允许数字值(同时也允许step="0.5“继续工作-即10.5将仍然有效,即使”。是非数字)

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-07-14 14:36:01

能够用这个正则表达式解决这个问题:

代码语言:javascript
复制
~r/^\d+(?:\.[05])?$/
票数 0
EN

Stack Overflow用户

发布于 2021-06-21 08:24:00

我可以在IE 11中复制这个问题。为了解决这个问题,我们可以添加regex。示例代码如下所示,它只允许一个小数点,并且在IE11中工作得很好:

代码语言:javascript
复制
<input type="number" step="0.5" required oninput="this.value = this.value.replace(/[^0-9.]/g, '').replace(/(\..*?)\..*/g, '$1');" />

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68057593

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档