最全正则表达式总结:验证QQ号、⼿机号、Email、中⽂、邮
编、⾝份证、IP地址等
什么是 RegExp?
RegExp 是正则表达式(Regular expression)的缩写,作⽤是对字符串执⾏模式匹配。
通常⽤于格式验证、正则替换、查⼦串等
各种编程语⾔的正则表达式基本相同,不同的语⾔可能会有⼀些细⼩的差别
RegExp 语法
1.// 直接实例化
2.var reg = new RegExp(pattern [, flags])
3.// 隐式创建(推荐)
4.var reg = /pattern/flags;
参数 pattern 是⼀个字符串,指定了正则表达式的模式或其他正则表达式。
参数 [, flags] 是⼀个可选的字符串,包含属性 “g”(global )、”i” (ignoreCase)和 “m”(multiline)。
ECMAScript 标准化之前,不⽀持 m 属性。如果 pattern 是正则表达式,⽽不是字符串,则必须省略该参数。
概念:⼦表达式
在正则表达式中,使⽤括号括起来的内容是⼀个⼦表达式,⼦表达式匹配到的内容会被系统捕获⾄缓冲区,使⽤\n(n:数字)来反向引⽤系统的第n号缓冲区的内容。
场景:后⾯的内容要求与前⾯的⼀致,可以使⽤⼦表达式
1.// 查连续相同的四个数字
2.var str = "1212ab45677778cd";
3.var reg = /(\d)\1\1\1/gi;
5.// OUTPUT:7777
概念:⽅括号(字符簇)
1.var str = "Is this all there is?";
2.var patt1 = /[a-h]/g;
3.document.write(str.match(patt1));
4.// OUTPUT:h,a,h,e,e
⽅括号作⽤
⽅括号作⽤
[abc]查⽅括号之间的任何字符。
[^abc]查任何不在⽅括号之间的字符。
[0-9]查任何从 0 ⾄ 9 的数字。同 \d
[a-z]查任何从⼩写 a 到⼩写 z 的字符。
[A-Z]查任何从⼤写 A 到⼤写 Z 的字符。
[A-z]查任何从⼤写 A 到⼩写 z 的字符。
[0-9a-zA-Z]查0-9,a-z,A-Z
概念:元字符
元字符(Metacharacter)是拥有特殊含义的字符:
元字符 | 作⽤
—|—
\ | 转义符(、)、/、\
| | 选择匹配符,可以匹配多个规则
.
| 查单个字符,除了换⾏和⾏结束符。
\w | 查单词字符。字符 ( 字母,数字,下划线_ )
\W | 查⾮单词字符。
\d | 查数字。
\D | 查⾮数字字符。
\s | 查空⽩字符。空格
\S | 查⾮空⽩字符。
\b | 匹配单词边界。
\B | 匹配⾮单词边界。
\0 | 查 NUL 字符。
\n | 查换⾏符。
\f | 查换页符。
\r | 查回车符。
\t | 查制表符。
\v | 查垂直制表符。
xx | 查以⼋进制数 xxx 规定的字符。
dd | 查以⼗六进制数 dd 规定的字符。
\uxxxx | 查以⼗六进制数 xxxx 规定的 Unicode 字符。
概念:量词
量词作⽤
n+匹配任何包含⾄少⼀个 n 的字符串。同 {1,}
n*匹配任何包含零个或多个 n 的字符串。同 {0,}
n?匹配任何包含零个或⼀个 n 的字符串。同 {0,1}
n{X}匹配包含 X 个 n 的序列的字符串。
n{X,Y}匹配包含 X ⾄ Y 个 n 的序列的字符串。
n{X,}匹配包含⾄少 X 个 n 的序列的字符串。
n$匹配任何结尾为 n 的字符串。
^n匹配任何开头为 n 的字符串。注意 /[^a] / 和 /^ [a]/是不⼀样的,前者是排除的,后者是代表⾸位。
(?=n)匹配任何其后紧接指定字符串 n 的字符串。正向预查
(?!n)匹配任何其后没有紧接指定字符串 n 的字符串。反向预查
RegExp 对象⽅法
test()
test() ⽅法检索字符串中是否存在指定的值。返回值是 true 或 false。
1.var patt1 = new RegExp('e');
3.// OUTPUT:true
4.var patt2 = new RegExp('ee');
6.// OUTPUT:false
1.// 判断是不是QQ号
2.// 1 ⾸位不能是0  ^[1-9]
3.// 2 必须是 [5, 11] 位的数字 \d{4, 9}
4.var str = '80583600';
5.var regexp = /^[1-9][0-9]{4,10}$/gim;
6.if (st(str)) {
7.    alert('is');
8.} else {
9.    alert('no');
10.}
exec()
exec() ⽅法检索字符串中的指定值。返回值是被到的值。如果没有发现匹配,则返回 null。
1.var patt1 = new RegExp('e');
3.// OUTPUT:e
4.var patt2 = new RegExp('ee');
6.// OUTPUT:null
compile()
compile() 既可以改变检索模式,也可以添加或删除第⼆个参数。
1.var patt1=new RegExp("e");
2.document.st("The best things in life are free")); // true
3.// 改变了检索模式
4.patt1pile("eee");
5.document.st("The best things in life are free")); // false
⽀持正则表达式的 String 对象的⽅法
search 检索与正则表达式相匹配的值。
1.var str = "Visit W3School!"
3.// OUTPUT:6
match 到⼀个或多个正则表达式的匹配。
1.var str="1 plus 2 equal 3"
3.// OUTPUT:1,2,3
replace 替换与正则表达式匹配的⼦串。
1.var str = "Visit Microsoft!"
3.// OUTPUT:Visit W3School!
1.// 重复项最多的字符个数
2.var str = 'g21ss4aeba_ersb43sgnnsssstht6sss60snnsj8resw0_ss';
3.// split : 将字符串转化为数组
4.// sort : 对数组排序,ASCII
5.// join : 将数组转化为字符串
6.var str_new = str.split('').sort().join('');
7.document.write(str + '<br>');
8.document.write(str.split('') + '<br>');
9.document.write(str.split('').sort() + '<br>');
10.document.write(str.split('').sort().join('') + '<br>');
11.// 匹配字符,且重复这个字符,重复次数⾄少⼀次。
12.var regexp = /(\w)\1+/g;
13.var index = 0;
14.var value = '';
15.place(regexp, function($0, $1) {
16.    // document.write($0);
17.    // document.write($1);
18.    if (index < $0.length) {
19.        index = $0.length;
20.        value = $1;
21.    }
22.});
23.document.write('重复项最多的字符是:' + value + ',个数是:' + index);
24.// OUTPUT:
25.// 0012344668__aabbeeegghjnnnnrrssssssssssssssssttw
26.// 重复项最多的字符是:s,个数是:16
split 把字符串分割为字符串数组。
1.var str = "How are you doing today?"
2.document.write(str.split(/\s+/));
3.// OUTPUT:How,are,you,doing,today?
经验:
检验格式(邮箱格式、IP格式)是否正确,⽤test()
抓取星期(如所有⼿机号),⽤exec()、match()
替换敏感词汇,⽤replace()
常见的正则表达式校验
1.// 常见的正则表达式校验
2.// QQ号、⼿机号、Email、是否是数字、去掉前后空格、是否存在中⽂、邮编、⾝份证、URL、⽇期格式、IP
3.var myRegExp = {
4.    // 检查字符串是否为合法QQ号码
5.    isQQ: function(str) {
6.        // 1 ⾸位不能是0  ^[1-9]
7.        // 2 必须是 [5, 11] 位的数字  \d{4, 9}
8.        var reg = /^[1-9][0-9]{4,9}$/gim;
9.        if (st(str)) {
10.            console.log('QQ号码格式输⼊正确');
11.            return true;
12.        } else {
13.            console.log('请输⼊正确格式的QQ号码');
14.            return false;
15.        }
16.    },
17.    // 检查字符串是否为合法⼿机号码
18.    isPhone: function(str) {
19.        var reg = /^(0|86|17951)?(13[0-9]|15[012356789]|18[0-9]|14[57]|17[678])[0-9]{8}$/;
20.        if (st(str)) {
21.            console.log('⼿机号码格式输⼊正确');
22.            return true;
23.        } else {
24.            console.log('请输⼊正确格式的⼿机号码');
25.            return false;
26.        }
27.    },
28.    // 检查字符串是否为合法Email地址
js中文正则表达式29.    isEmail: function(str) {
30.        var reg = /^\w+((-\w+)|(\.\w+))*\@[A-Za-z0-9]+((\.|-)[A-Za-z0-9]+)*\.[A-Za-z0-9]+$/;
31.        // var reg = /\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*/;
32.        if (st(str)) {
33.            console.log('Email格式输⼊正确');
34.            return true;
35.        } else {
36.            console.log('请输⼊正确格式的Email');
37.            return false;
38.        }
39.    },
40.    // 检查字符串是否是数字
41.    isNumber: function(str) {
42.        var reg = /^\d+$/;
43.        if (st(str)) {
44.            console.log(str + '是数字');
45.            return true;
46.        } else {
47.            console.log(str + '不是数字');
48.            return false;
49.        }
50.    },
51.    // 去掉前后空格
52.    trim: function(str) {
53.        var reg = /^\s+|\s+$/g;
54.        place(reg, '');
55.    },
56.    // 检查字符串是否存在中⽂
57.    isChinese: function(str) {
58.        var reg = /[\u4e00-\u9fa5]/gm;
59.        if (st(str)) {
60.            console.log(str + ' 中存在中⽂');
61.            return true;
62.        } else {
63.            console.log(str + ' 中不存在中⽂');
64.            return false;
65.        }
66.    },
67.    // 检查字符串是否为合法
68.    isPostcode: function(str) {
69.        // 起始数字不能为0,然后是5个数字  [1-9]\d{5}
70.        var reg = /^[1-9]\d{5}$/g;
71.        // var reg = /^[1-9]\d{5}(?!\d)$/;
72.        if (st(str)) {
73.            console.log(str + ' 是合法的邮编格式');
74.            return true;
75.        } else {
76.            console.log(str + ' 是不合法的邮编格式');
77.            return false;
78.        }
79.    },
80.    // 检查字符串是否为合法⾝份证号码
81.    isIDcard: function(str) {
82.        var reg = /^(^[1-9]\d{7}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])\d{3}$)|(^[1-9]\d{5}[1-9]\d{3}((0\d)|(1[0-2]))(([0|1|2]\d)|3[0-1])((\d{4})|\d{3} [Xx])$)$/;
83.        if (st(str)) {
84.            console.log(str + ' 是合法的⾝份证号码');
85.            return true;
86.        } else {
87.            console.log(str + ' 是不合法的⾝份证号码');
88.            return false;
89.        }
90.    },
91.    // 检查字符串是否为合法URL
92.    isURL: function(str) {
93.        var reg = /^https?:\/\/(([a-zA-Z0-9_-])+(\.)?)*(:\d+)?(\/((\.)?(\?)?=?&?[a-zA-Z0-9_-](\?)?)*)*$/i;
94.        if (st(str)) {
95.            console.log(str + ' 是合法的URL');
96.            return true;
97.        } else {
98.            console.log(str + ' 是不合法的URL');
99.            return false;
100.        }
101.    },
102.    // 检查字符串是否为合法⽇期格式 yyyy-mm-dd
103.    isDate: function(str) {
104.        var reg = /^[1-2][0-9][0-9][0-9]-[0-1]{0,1}[0-9]-[0-3]{0,1}[0-9]$/;
105.        if (st(str)) {
106.            console.log(str + ' 是合法的⽇期格式');
107.            return true;
108.        } else {
109.            console.log(str + ' 是不合法的⽇期格式,yyyy-mm-dd');
110.            return false;
111.        }
112.    },
113.    // 检查字符串是否为合法IP地址
114.    isIP: function(str) {
115.        // 1.1.1.1  四段  [0 , 255]
116.        // 第⼀段不能为0
117.        // 每个段不能以0开头
118.        //

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。