Reputation: 4097
Regex pattern ^(\+?6?01)[0|1|2|3|4|6|7|8|9]\-*[0-9]{7,8}$
in HTML5 input return error. I tested the regex, no errors on regex101.com as well as in my php code. But in HTML5 it does not function as it be. My code:
<input class="mdl-textfield__input" name="mobile_number" type="text" pattern="^(\+?6?01)[0|1|2|3|4|6|7|8|9]\-*[0-9]{7,8}$">
Error:
textfield.js:146 Pattern attribute value ^(+?6?01)[0|1|2|3|4|6|7|8|9]-*[0-9]{7,8}$ is not a valid regular expression: Uncaught SyntaxError: Invalid regular expression: /^(+?6?01)[0|1|2|3|4|6|7|8|9]-*[0-9]{7,8}$/: Invalid escape
Anyone can help me? Thanks in advance for any helps offered.
My tested regex: https://regex101.com/r/1WsVwo/1
Upvotes: 4
Views: 25640
Reputation: 1
Tested further, below regex enforce user to key in dash (-
):
^(\+?6?01)[02-46-9][-][0-9]{7}$|^(\+?6?01)[1][-][0-9]{8}$
Enter phone number in 01Z-XXXXXXX
or 011-XXXXXXXX,
where X
is 0 to 9 and Z
is 0, 2, 3, 4, 6, 7, 8, 9
Upvotes: 0
Reputation: 191
Just to clarify, the answer of @elixenide is good enough for this question. But I do have some improvement for the regex part. First, +60 / 60 is Malaysia country calling code, then it follow by 9/10 digit number. But only one kind of number having 10 digit number after country calling code while others is 9 digit. For example:
So this is my improvement on how the regex should be
pattern="^(\+?6?01)[02-46-9]-*[0-9]{7}$|^(\+?6?01)[1]-*[0-9]{8}$"
Here are the link to regex101, try it
My sample output in regex101
Upvotes: 9
Reputation: 44841
You have a few problems with your regex. The one causing the "invalid escape" error is that you have \-
, but you do not need to (and should not) escape the hyphen. You should just have -
. A proper version of your input
is:
<input class="mdl-textfield__input" name="mobile_number" type="text" pattern="^(\+?6?01)[0-46-9]-*[0-9]{7,8}$">
In that example, I've also replaced the group [0|1|2|3|4|6|7|8|9]
with the cleaner and more accurate [0-46-9]
. In a character group (like [...]
), the pipe symbol (|
) is just another character, with no special meaning. So, for example, [0|1]
doesn't just match 0
or 1
; it also matches a literal |
character, which is not what you wanted. You might find this post helpful: Reference - What does this regex mean?
Upvotes: 6
Reputation: 151
<input class="mdl-textfield__input" name="mobile_number" type="text" pattern="(\+?6?01)[0-9]{7,8}">
i change your pattern to (\+?6?01)[0-9]{7,8}
*Update: (\+?6?01)[0-46-9]-*[0-9]{7,8}
See demo
Upvotes: -1
Reputation: 67
because your syntax error, invalid escape - => -
this correct:
<input class="mdl-textfield__input" name="mobile_number" type="text" pattern="^(\+?6?01)[0|1|2|3|4|6|7|8|9]-*[0-9]{7,8}$">
Upvotes: -1