创建方式
根据 JavaScript高程 上面介绍,有两种方式创建正则表达式:
new RegExp()
var reg = new RegExp('n', 'gi'); // 全局匹配字母n,且不区分大小写。
- 其中第二个参数是可选的,三种值:
g
:全文查找、i
:不区分大小写、m
:多行查找;
/xxx/gi
var reg = /a/g; // 代表全局搜索a
常用方法
-
test()
方法用于检测一个字符串是否匹配某个模式,如果字符串中含有匹配的文本,则返回true
,否则返回false
。
var str = 'my name is Dave';
var reg = new RegExp('n', 'gi');
reg.test(str); // true
-
search()
方法检索与正则表达式相匹配的子字符串,并返回子串的起始位置。
var str= 'my name is busynnn';
console.log(str.search(/is/g)); // 8
-
match()
存放匹配结果的数组。该数组的内容依赖于 regexp 是否具有全局标志 g。 如果没找到匹配结果返回 null 。
var str = "The rain in SPAIN stays mainly in the plain";
var n=str.match(/ain/gi); // ain,AIN,ain,ain
4.replace()
用传入的字符串替换正则匹配的字符串:
eg: 替换敏感字
var prag = '大约一个月前,小米在小米5X发布会上同时发布了MIUI9系统,和以往的系统相比,MIUI9系统的一大特点是应用启动速度快,同时还可以通过新的几大功能,如传送门、信息助手、快速查找照片、分屏等功能全面提升手机使用效率。'
+ '自2010年8月16日发布以来, MIUI系统已连续更新超过340周。 小米联合创始人、 MIUI负责人洪锋透露, 截至目前, MIUI全球用户已经突破2 .8 亿, 覆盖142个国家地区。'
+ 'MIUI发布至今已经过去整整七年时间, 从第一代到第九代, MIUI所承载的角色也发生了变化, 但洪锋觉得无论如何, 作为一个手机系统, MIUI的宗旨还是要满足80 % 以上用户的实际需求, 提升用户使用手机的效率。'
+ '36 氪对洪锋进行了一次专访, 谈了谈手机系统行业目前的整体局势。 在语音交互和AI大行其道的今天, 作为手机的系统还能有哪些新的突破和畅想空间。 ';
var reg3 = /小米|MIUI/g; // 替换字符串中的 ‘小米’和‘MIUI’
console.log(prag.replace(reg3, '**'));
var newPrag = prag.replace(reg3, function(s) { // 传一个函数,函数的参数s代表匹配的 关键字
var temp = '';
for (var i = 0; i < s.length; i++) {
temp += '*';
}
return temp;
});
运行结果:
一些常用符号
[], (), {}, ^, $
[]
是定义匹配的字符范围。[0-9]表示查找任何从 0 至 9 的数字。{}
一般用来表示匹配的长度。/a{n}/
表示匹配连续n个a
。/a{n, m}/
表示匹配连续m-n
个a
()
的作用是提取匹配的字符串。表达式中有几个()就会得到几个相应的匹配字符串。比如(\s+)表示连续空格的字符串^
匹配一个字符串的开头,比如 (^a) 就是匹配以字母a开头的字符串$
匹配一个字符串的结尾,比如 (b$) 就是匹配以字母b结尾的字符串^
还有另个一个作用就是取反,比如[^xyz]表示匹配的字符串不包含xyz
需要注意的是:如果^出现在[]中一般表示取反,而出现在其他地方则是匹配字符串的开头。
\d
匹配一个非负整数, 等价于 [0-9];\s
匹配一个空白字符;\S
和它相反\w
匹配一个英文字母或数字,等价于[0-9a-zA-Z];\W
和它相反.
匹配除换行符以外的任意字符,等价于[^\n]*
表示匹配前面元素0次或多次,比如(\s*)就是匹配0个或多个空格;+
表示匹配前面元素1次或多次,比如(\d+)就是匹配由至少1个整数组成的字符串;?
表示匹配前面元素0次或1次,相当于{0,1},比如(\w?) 就是匹配最多由1个字母或数字组成的字符串 。
使用情况
1.验证
用于验证时,通常需要在前后分别加上^和$,以匹配整个待验证字符串;
2.搜索替换
搜索/替换时是否加上此限定则根据搜索的要求而定,此外,也有可能要在前后加上\b而不是^和$
字符类匹配
[…] 查找方括号之间的任何字符
[^…] 查找任何不在方括号之间的字符
[a-z] 查找任何从小写 a 到小写 z 的字符
[A-Z] 查找任何从大写 A 到大写 Z 的字符
[A-z] 查找任何从大写 A 到小写 z 的字符
. 查找单个字符,除了换行和行结束符
\w 查找单词字符,等价于[a-zA-Z0-9]
\W 查找非单词字符,等价于[^a-zA-Z0-9]
\s 查找空白字符
\S 查找非空白字符
\d 查找数字,等价于[0-9]
\D 查找非数字字符,等价于[^0-9]
\b 匹配单词边界
\r 查找回车符
\t 查找制表符
\0 查找 NULL 字符
\n 查找换行符
重复字符匹配
{n,m} 匹配前一项至少n次,但不能超过m次
{n,} 匹配前一项n次或更多次
{n} 匹配前一项n次
n? 匹配前一项0次或者1次,也就是说前一项是可选的,等价于{0,1}
n+ 匹配前一项1次或多次,等价于{1,}
n* 匹配前一项0次或多次,等价于{0,}
n$ 匹配任何结尾为 n 的字符串
^n 匹配任何开头为 n 的字符串
?=n 匹配任何其后紧接指定字符串 n 的字符串
?!n 匹配任何其后没有紧接指定字符串 n 的字符串
匹配特定数字
^[1-9]\d$ 匹配正整数
^-[1-9]\d$ 匹配负整数
^-?[0-9]\d$ 匹配整数
^[1-9]\d|0$ 匹配非负整数(正整数 + 0)
^-[1-9]\d|0$ 匹配非正整数(负整数 + 0)
^[1-9]\d.\d|0.\d[1-9]\d$ 匹配正浮点数
^-([1-9]\d.\d|0.\d[1-9]\d)$ 匹配负浮点数
^-?([1-9]\d.\d|0.\d[1-9]\d|0?.0+|0)$ 匹配浮点数
^[1-9]\d.\d|0.\d[1-9]\d|0?.0+|0$ 匹配非负浮点数(正浮点数 + 0)
^(-([1-9]\d.\d|0.\d[1-9]\d*))|0?.0+|0$ 匹配非正浮点数(负浮点数 + 0)
匹配特定字符串
^[A-Za-z]+$ 匹配由26个英文字母组成的字符串
^[A-Z]+$ 匹配由26个英文字母的大写组成的字符串
^[a-z]+$ 匹配由26个英文字母的小写组成的字符串
^[A-Za-z0-9]+$ 匹配由数字和26个英文字母组成的字符串
^\w+$ 匹配由数字、26个英文字母或者下划线组成的字符串
参考内容: