2

我有一个需要收集单个号码的字段

<input type="text" patern="" name="number" required="required" />

现在值可以是 1-9999 但是我有一些我不允许的数字,比如说

15
21 
532 

如果输入了其中一个数字,是否可以使用正则表达式模式强制表单提交失败?

4

3 回答 3

2

试试这个正则表达式:

/^(?!(?:15|21|532|0+)$)\d{1,4}$/

如果你仔细看,你会发现我0在不允许的列表中包含了数字15,,。这样做的原因是正则表达式匹配任何具有 1 到 4 位数字的数字,但您只需要 range 。215321-9999

单击下面的链接以获取此正则表达式的运行演示。

正则表达式 101

JS小提琴

于 2015-10-22T01:15:56.667 回答
0

尝试设置type="submit"disabledif 15, 21, 532value of input type="number", usingString.prototype.match()

var input = document.querySelector("input[type=number]")
var label = document.querySelector("[for=number]");
input.oninput = function() {
  var val = this.value;
  var matches = ["15","21","532"];
  var match = matches.indexOf(val) !== -1;
  this.nextElementSibling.disabled = match;
  this.style.color = match ? "red" : "inherit";
  label.innerHTML =  match ? "Invalid number: <mark style=color:red>" 
                             + val + "</mark>" 
                           : "";
}
<form>
  <input type="number" min="1" max="9999" pattern="" name="number" required="required" id="number" />
  <input type="submit" /><br />
  <label for="number"></label>
</form>

于 2015-10-22T01:22:49.653 回答
-1
function isValidNumber(num){
  if (isNaN(+num))
    return false;

  var cant_match = [ 15, 21, 532 ];
  return !( cant_match.indexOf(+num) >= 0 );
}


// Example call
isValidNumber( document.querySelector("input[name=number]").value );

很简单:

  • isNaN(+num)如果传递给函数的值不是实数或整数,则失败(例如,'32 456' 失败)
  • 然后根据错误数字数组检查传递的值;如果索引 >= 0,则在数组中找到该数字
于 2015-10-22T04:52:11.533 回答