正则表达式
正则表达式(Regular Expression,简称为RegEx),是用来匹配一系列符合某个规则的字符串的表达式
正则表达式独立于编程语言,几乎所有的编程语言甚至文字处理软件都支持正则表达式
应用场景
- 从大量文本中查找符合某一规则的文本
- 验证用户输入是否符合格式
基本语法
/正则表达式主体/修饰符(可选)
修饰符为可选,但一般使用g,代表全局匹配
split()
replace()
search()
match()
在以上这些方法中都可使用正则表达式
常用的使用正则表达式的方法,支持传入字符串或正则表达式
var a = "123145"
var b = a.replace(/1/g,0)
//b : 023045
var a = "123145"
var b = a.search(/1/g)
//b : 0
var a = "123145"
var b = a.match(/1/g)
//b : ["1","1"]
正则对象
创建正则对象
var patt = new RegExp('1','g')
var patt = /1/g
正则对象有三个方法compile()、exec()、test()
- compile()
用于改变 RegExp - exec()
检索字符串中的指定值。返回值是被找到的值。如果没有发现匹配,则返回 null
var str = '1231'
var patt = /1/g
console.log(patt.exec(str))
- test()
检索字符串中的指定值。返回值是 true 或 false
var str = '1231'
var patt = /1/g
console.log(patt.test(str)) //true
当使用了修饰符g时,test()和exec()会储存每一次运行的记录,下一次运行会从上一次储存的位置开始
var str = '1231'
var patt = /1/g
console.log(patt.exec(str))
console.log(patt.exec(str))
console.log(patt.exec(str))
正则表达式规则
[] 匹配字符组
满足[]内的任意字符即匹配成功
/[js]/g 可匹配j与s
区间
/[0123456789]/g 等同于/[0-9]/g
/[0-9a-zA-Z]/g 可匹配所有的数字及大小写字母
\ 转义字符
/-/g 可匹配字符“-”
^ 取反
在字符数组开头使用 ^ 字符实现取反操作
/[^0-9]/g 可匹配所有非数字的字符
- \w 匹配任意字符,包括[0-9],[a-z],[A-Z]及下划线
- \d 匹配数字,包括[0-9]
- \s 匹配空白 包括空格、制表符、换行符等
- \W 匹配非字符
- \D 匹配非数字
- \S 匹配非空白
\b 单词边界
仅匹配有边界的单词
/\bhello/g 匹配 “hellohello hello-hello” 第二个hello无法匹配成功,因为该单词前面紧接其他字符,即没有边界
/\bhello\b/g 匹配 “hellohello hello-hello” 第一个和第二个hello都无法匹配成功
^ $ 开始和结束
/^h/g 匹配以h开头的字符串
/s$/g 匹配以s结尾的字符串
. 任意字符
.代表任意字符、但不能代表\n换行符
/Jav./g 可匹配Java、Javs、Javo、Jave
/J…/g 可匹配J开头的4位字符
? 可选字符
?可以指定某个字符可选,出现0次或1次
/colou?r/g 可匹配color和colour
/Ja.?a/g 可匹配Jaa和Java
{N} 重复
{N}代表某字符或字符组出现N次
/\d{4}/g 代表任意4位数字
{M,N} 重复区间
代表某个字符或字符组出现M到N次
/\d{3,5}/g 可匹配3位、4位、5位数字
? 非贪婪模式
/\d{3,5}/g 默认为贪婪模式,如“123456”会匹配前5个字符
/\d{3,5}?/g 为非贪婪模式,如“123456”会匹配前3个字符
{N,}开闭区间
{N,}代表某字符或字符组出现N次到无限次
/\d{1,}/g 代表任意数字出现1次到无限次
/\d{0,}/g 代表任意数字出现0次到无限次
+ *
简写
+表示{1,} 即/d+/g 等同于 /\d{1,}/g
*
表示{0,} 即/d*/g 等同于 /\d{0,}/g