199,一个被正则表达式遗忘的号码段?
程序员文章站
2022-05-17 14:49:29
前不久换手机号,东想西想,最后选了个电信的199号码段。这下好了,当我注册某些网站的账号时,弹出个非法号码字段,惊了!怎么回事??? 于是想到:当我们注册某网站的时候,需要输入手机号进行注册。比如唯品会的注册界面,当你输入的手机号不对时就会出现错误提示:请输入正确的手机号码。 这个是怎么实现的呢?比 ......
前不久换手机号,东想西想,最后选了个电信的199号码段。这下好了,当我注册某些网站的账号时,弹出个非法号码字段,惊了!怎么回事???
于是想到:当我们注册某网站的时候,需要输入手机号进行注册。比如唯品会的注册界面,当你输入的手机号不对时就会出现错误提示:请输入正确的手机号码。
这个是怎么实现的呢?比如我那个199开头的电信号,总是被误认为非法号码。究其原因,原来是正则表达式搞的鬼。
首先了解一下什么是正则表达式?打开百度百科,它的解释如下:
所以,在程序设计上,正则表达式通常用于匹配字符串,一般是匹配有规律的字符串,多数用于表单验证。比如注册网站时,我们常常需要按要求填写的那些账号密码信息等。
正则表达式怎么写出来的,首先让我们看看正则表达式是什么样子的?
功能实现 | 正则表达式 |
email地址 | ^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$ |
域名 | [a-za-z0-9][-a-za-z0-9]{0,62}(/.[a-za-z0-9][-a-za-z0-9]{0,62})+/.? |
身份证号 | ^\d{15}|\d{18}$ |
帐号是否合法 | ^[a-za-z][a-za-z0-9_]{5,15}$ |
坐好了,准备发车!接下来看看正则表达式是怎么写的?这些字符代表什么意思?以及手机号的正则表达式是怎样的?
. | 表示除了换行之外的所有单个字符 | \w | 表示匹配数字,字母,下划线[a-z0-9a-z _] |
* | 表示匹配任意多次可以是0,一般结合其它字符使用 | \w | 表示匹配非数字,非字母,非下划线[^a-z0-9a- z_] |
[] | 表示范围 | \d | 表示数字[0-9] |
^ | 表示非 | \d | 表示非数字[^0-9] |
+ | 表示至少出现一次 | {n,} | 至少匹配n次,{n}:表示匹配n次,{n,m}:表示最少n次,最多m次 |
/^ | 从头匹配 |
$/ | 从尾部匹配 |
\b | 匹配边界 |
\s | 匹配空格 |
| | 或者的意思 |
() | 表示分组 |
那么常用的手机号的正则表达式是怎样的?
首先得了解一下三大运营商的各号码段如何:
于是满足所有条件的手机号码的正则表达式诞生了:
/^1([358][0-9]|4[579]|66|7[0135678]|9[89])\d{8}$/
上一篇: JS类和继承实例讲解