我有一个数字输入文本框,我想允许用户编辑,但不希望允许用户输入除数字之外的任何其他文本.我希望他们只能使用数字输入框上的箭头.
<input type = "number" min="0" max="10" step="0.5" input id="rating" name = "rating" class = "login-input" placeholder = "Rating 1-5:" value="0">@H_502_3@
解决方法
@H_301_7@ 您可以通过纯JavaScript实现此目的.在脚本中创建此函数并将其命名为onkeypress事件处理程序.<script type="text/javascript"> function AllowNumbersOnly(e) { var code = (e.which) ? e.which : e.keyCode; if (code > 31 && (code < 48 || code > 57)) { e.preventDefault(); } } </script>@H_502_3@<input type="text" id="OnlyNumbers" onkeypress = "return AllowNumbersOnly(event)" />@H_502_3@工作Demo.
但是我会推荐使用jQuery编写JS的不引人注目的风格,因为我不喜欢污染HTML.
$(function(){ $('#OnlyNumbers').keydown(function(e){ return AllowNumbersOnly(e); }); });@H_502_3@要限制每个字符,可以省略if条件,并使用
preventDefault()
禁用所有键.此外,您也可以使用return false,但在这种情况下,preventDefault()更好,并且应该明智地选择返回false.很高兴知道difference between both of them.