输入-限制数字范围

Input - Limit number range

本文关键字:数字 范围 输入      更新时间:2023-09-26

我有一个文本input,我想将其限制为仅数字。没有其他字符。我还想限制从0到255。

如果输入了"非法"字符或金额,我希望它等待一秒钟,然后删除该字符或数字。到目前为止,我能够获得非法字符。

我想做的是:

  • 让它等待一秒钟,然后删除它
  • 限制0-255之间的数字

如果输入的数字超过255,我只希望最后一个数字等待,然后删除它自己。就像"非法"字符一样。

我已经实现了非法字符。这是代码:

JSFiddle

$('input[name="number"]').keyup(function(e) {
  if (/'D/g.test(this.value)) {
    // Filter non-digits from input value.
    this.value = this.value.replace(/'D/g, '');
  }
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input name="number" />

尝试使用if条件检查this.value是否大于255,如果为true,则使用String.prototype.slice()this.value设置为输入的前两个字符

让它等一下怎么样?

尝试使用setTimeout()

function disableInput(el) {
  // create array of checks on `el.value`
  var checks = [/'D/g.test(el.value), el.value > 255];
  // if `el.value` contains non-digit character,
  // or is greater than 255 ;
  // `Array.prototype.some()` checks for `true` value
  // if either `checks[0]`, or `checks[1]` is `true` do stuff
  // else set `el.value` to user input
  if (checks.some(Boolean)) {
    // disable input
    $(el).prop("disabled", true)
    // delay 1 second
    setTimeout(function() {
      if (checks[0]) {
        // Filter non-digits from input value.
        el.value = el.value.replace(/'D/g, '');
      }
      // if `this.value` greater than 255 , set `this.value` to 
      // first two characters of input
      if (checks[1]) {
        el.value = el.value.slice(0, 2);
      };
      $(el).prop("disabled", false).val(el.value).focus()
    }, 1000)
  }      
}
$('input[name="number"]').keyup(function(e) {
  disableInput(this)
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input name="number" />