什么是正则表达式
假设我们有一个字符串:abc_efg_abc_3
现在想要匹配这个字符串的abc_3
你可以这样写:
$定位符:表示字符串末
/abc_3$/
更好的写法:
\d元字符:表示任意数字
/abc_\d$/
正则表达式用于对字符串模式匹配及检索替换
一个简单正则的表达式就像上面一样,虽然我们已经会写了,但是还没正式介绍正则的写法
如何创建正则
有两种创建正则的方法:
- js风格
new RegExp(pattern [, flags])
- perl风格
/pattern/[flags]
我们一般采用perl风格,简单明了。
有必要说明一下上面已经出现的一些概念:定位符,元字符,pattern(模式),标识(flags)
定位符
- ^ 字符串的开始
- $ 字符串的结束
元字符
罗列几个简单常用的:
- . 查找单个字符,除了换行和行结束符。
- \w 查找单词字符。
- \W 查找非单词字符。
- \d 查找数字。
标识flags
- i 执行对大小写不敏感的匹配。
- g 执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。
- m 执行多行匹配。
正则的方法
test方法:reg.test(str)
,返回一个布尔值,如果匹配到了返回true
/abc_\d$/.test('abc_efg_abc_3') // return true
exec方法:reg.exec(str)
如果匹配成功,exec() 方法返回一个数组,并更新正则表达式对象的属性。返回的数组将完全匹配成功的文本作为第一项,将正则括号里匹配成功的作为数组填充到后面。
如果匹配失败,exec() 方法返回 null。
/a/.exec('ccc_a_b') // return ['a']
这就是正则最简单的使用方法,但是还有其他的几个方法
正则的字符串方法
- search 检索与正则表达式相匹配的值
- match 找到一个或多个正则表达式的匹配
- replace 替换与正则表达式匹配的子串
- split 把字符串分割为字符串数组
正则实例:手机号
正确匹配一个11位的手机号码
一般手机号的网段有:13x,15x,17x,18x
/^(13\d|15\d|17[789]|18\d)\d{8}$/
量词:{8},表示8位
方括号[]:表示可选其中任意一个字符
或|:或者
量词
如果不加量词,默认一个
- {8} 8个
- {3,10} 3~10
- {5,} 最少5个
- + | {1,}大于等于1个
- {0,}可以没有
- ? | {0,1}有或者没有
方括号[]
- [0-9] 0~9任意一个
- [^0-9] 排除0~9
- [a-z0-9A-Z] 任意数字,字母大小写