0

我有三个不同的电话号码输入字段。每个字段应该只允许美国电话号码格式。这是示例:

(564) 332-9088 //allowed format.

用户应该只能以我上面示例中的格式输入电话号码。所以前三个数字应该在大括号中,()然后是空格(可以忽略),然后是 3 个数字,然后是-破折号和最后四个数字。我已经创建了模式正则表达式,但这不需要(). 用户也可以以这种格式输入电话号码,这336-678-8999是不允许的。

<form name="testFrm" id="testFrm" method="POST" action="#">
  <label for="wphone">Work Phone:</label>
  <input type="tel" name="phoneW" id="phoneW" pattern="(?:\(\d{3}\)|\d{3})[- ]?\d{3}[- ]?\d{4}" maxlength="14" title="US based Phone Number in the format of: (123) 456-7890" placeholder="(xxx) xxx-xxxx" required />
  <span><input type="submit" name="frmSubmit" id="frmSubmit" value="Submit" /></span>
</form>

如果有人知道我如何调整我的代码以仅接受,(xxx) xxx-xxxx请告诉我,或者如果您有更好的方法来解决这个问题。谢谢你。

4

1 回答 1

3

我认为这对您 (xxx) xxx-xxxx允许格式有用。这里的空格是可选的(xxx)

\(\d{3}\)[ ]?\d{3}[-]?\d{4}

解释

\(-> 匹配字符(字面意思(区分大小写)

\d-> 匹配一个数字(等于 [0-9])

{3}-> 量词——精确匹配 3 次

\)-> 从字面上匹配字符 )(区分大小写)

[ ]?-> 匹配 0 到 1 次之间的空间,尽可能多次,根据需要回馈(贪婪)

\d-> 匹配一个数字(等于 [0-9])

{3}-> 量词——精确匹配 3 次

[-]?-> 匹配 0 到 1 次之间的破折号,尽可能多次,根据需要回馈(贪婪)

\d-> 匹配一个数字(等于 [0-9])

{4}-> 量词——精确匹配 4 次

见演示:https ://regex101.com/r/Ws3c1t/1

于 2017-10-16T16:11:57.413 回答