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
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
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}$">
Here's a demo.
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?
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With