如何防止在输入字段中输入无效字符

IT技术 javascript regex dom-events
2021-03-09 19:42:52

Onkeydown,我运行以下 JavaScript:

function ThisOnKeyDown(el) {
   if (el.title == 'textonly') {
       !(/^[A-Za-zÑñ-\s]*$/i).test(el.value) ? el.value = el.value.replace(/[^A-Za-zÑñ-\s]/ig, '') : null;
   }
   if (el.title == 'numbersonly') {
       !(/^[0-9]*$/i).test(el.value) ? el.value = el.value.replace(/[^0-9]/ig, '') : null;
   }
   if (el.title == 'textandnumbers') {
       !(/^[A-Za-zÑñ0-9-\s]*$/i).test(el.value) ? el.value = el.value.replace(/[^A-Za-zÑñ0-9-\s]/ig, '') : null;
   }
}

这三个标题属性之一被赋予页面上的各种输入字段。只要无效字符被正确擦除,代码就可以工作,但直到输入下一个字符才有效。我想首先找到一种简单地拒绝无效输入的方法。我感谢您的帮助!

编辑:我在全球范围内创建事件。这是我如何做到的:

      function Globalization() {
      var inputs = document.getElementsByTagName('input');
      for (i = 0; i < inputs.length; i++) {
          inputs[i].onfocus = createEventHandler(
              ThisOnFocus, inputs[i]);
          inputs[i].onblur = createEventHandler(
              ThisOnBlur, inputs[i]);
          inputs[i].onkeydown = createEventHandler(
              ThisOnKeyDown, inputs[i]);
          inputs[i].onkeyup = createEventHandler(
              ThisOnKeyUp, inputs[i]);
      }
  }

Globalization() 正在运行 body.onload

因此,典型的输入字段具有 HTML,没有像这样的函数调用:

          <input id="AppFirstName" style="width: 150px;" type="text" maxlength="30" title="textonly"/>
6个回答

为了防止它首先被设置,您可以在 keydown 事件处理程序上返回 false,从而防止事件进一步传播。

我使用 jQuery 编写了下面的示例,但您可以在传统绑定时使用相同的函数。

尽管在服务器端验证也很重要,但为了用户友好性,客户端验证很重要。

$("input.number-only").bind({
    keydown: function(e) {
        if (e.shiftKey === true ) {
            if (e.which == 9) {
                return true;
            }
            return false;
        }
        if (e.which > 57) {
            return false;
        }
        if (e.which==32) {
            return false;
        }
        return true;
    }
});
'which' 属性现在已弃用,使用 'keyCode' 代替:developer.mozilla.org/en-US/docs/Web/Events/keydown
2021-04-23 19:42:52
作为参考,关键代码编号(9、57、32 等)代表 unicode 字符,列在此处:en.wikipedia.org/wiki/List_of_Unicode_characters
2021-05-15 19:42:52

上面的代码确实说 - 只允许数字。您可以通过添加异常来修改它,例如像这样说 BACKSPACE

<html>
    <head>
        <title></title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <script>
            function keyispressed(e){
                var charValue= String.fromCharCode(e.keyCode);
                if((isNaN(charValue)) && (e.which != 8 )){ // BSP KB code is 8
                    e.preventDefault();
                }
                return true;
            }
        </script>
    </head>    
    <body>
        <input type="text" onkeydown="return keyispressed(event);"/>
    </body>
</html>
var charval 需要是 var charValue
2021-04-24 19:42:52
$('.key-filter').keypress(function () {
    if (event.key.replace(/[^\w\-.]/g,'')=='') event.preventDefault();
});

如果使用 jquery 或

<input type="text" onkeypress="if (event.key.replace(/[^\w\-.]/g,'')=='') event.preventDefault();" />

只需将您想要允许的字符放在 ^ 之后的 [] 中。这允许所有字母数字 _ - 和 .

我宁愿使用正则表达式 test() 方法而不是 replace()。此外,返回 false 就足够了。
2021-04-26 19:42:52

我在以下位置找到了这个解决方案:http : //help.dottoro.com/ljlkwans.php

按预期工作。

<script type="text/javascript">
    function FilterInput (event) {
        var keyCode = ('which' in event) ? event.which : event.keyCode;

        isNumeric = (keyCode >= 48 /* KeyboardEvent.DOM_VK_0 */ && keyCode <= 57 /* KeyboardEvent.DOM_VK_9 */) ||
                    (keyCode >= 96 /* KeyboardEvent.DOM_VK_NUMPAD0 */ && keyCode <= 105 /* KeyboardEvent.DOM_VK_NUMPAD9 */);
        modifiers = (event.altKey || event.ctrlKey || event.shiftKey);
        return !isNumeric || modifiers;
    }
</script>

< body>
The following text field does not accept numeric input:
<input type="text" onkeydown="return FilterInput (event)" />< /body>

它允许文本和 !"#$%& 但您可以调整它,将这些添加到验证中,通过删除返回中的 ! 来只允许数字

代码可用于防止用户键入除数字以外的任何其他字符。

<html>
    <head>
        <title></title>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
        <script>
            function keyispressed(e){
                var charval= String.fromCharCode(e.keyCode);
                if(isNaN(charval)){
                    return false;
                }
                return true;
            }
        </script>
    </head>

    <body>
        <input type="text" onkeydown="return keyispressed(event);"/>
    </body>
</html>
值得注意的是:此代码还可以防止退格和 shif+箭头选择之类的事情。
2021-04-23 19:42:52
感谢您的回答!它帮助我意识到我需要返回 onkeydown 中的函数才能使其工作。
2021-05-06 19:42:52