正则表达式
正则表达式是国际标准,跨越语言
正则表达式是一个规则,用于验证字符串。
基础
- 字面量匹配
规则中直接书写字面量字符
- 特殊字符
.:匹配除换行符 \n 之外的任何单字符。要匹配 . ,请使用 \. 。
^:匹配输入字符串的开始位置。^ 还会与 \n 或 \r 之后的位置匹配。
$:匹配输入字符串的结尾位置。$ 还会与 \n 或 \r 之前的位置匹配。
- 转义符
\n:匹配一个换行符。等价于 \x0a 和 \cJ。
\r:匹配一个回车符。等价于 \x0d 和 \cM。
\t:匹配一个制表符。等价于 \x09 和 \cI。
\s:匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [ \f\n\r\t\v]。
\S:匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。
\b:匹配一个单词边界,即字与空格间的位置。
\B:非单词边界匹配。
\d:匹配一个数字字符。等价于 [0-9]。
\D:匹配一个非数字字符。等价于 [^0-9]。
\w:匹配字母、数字、下划线。等价于'[A-Za-z0-9_]'。
\W:匹配非字母、数字、下划线。等价于 '[^A-Za-z0-9_]'。
\u:匹配 n,其中 n 是一个用四个十六进制数字表示的 Unicode 字符。例如, \u00A9 匹配版权符号 (?)。
转义符可以将特殊字符转义
- 字符集
[字符范围]
匹配中文: [\u4e00-\u9FA5]
- 量词
前面的规则出现的次数
*:匹配前面的子表达式零次或多次。例如,zo* 能匹配 "z" 以及 "zoo"。* 等价于{0,}。
+:匹配前面的子表达式一次或多次。例如,'zo+' 能匹配 "zo" 以及 "zoo",但不能匹配 "z"。+ 等价于 {1,}。
?:匹配前面的子表达式零次或一次。例如,"do(es)?" 可以匹配 "do" 或 "does" 。? 等价于 {0,1}。
{n}: 匹配n个
{n,}: 匹配>=n个
{n,m}: 匹配n-m个
练习
- 写一个正则表达式,匹配手机号
【11位,第一位是1】
^1\d{10}$
- 姓名必须是3-6位的中文
^[\u4e00-\u9FA5]{3,5}$
- 密码必须是6-12位的字符,只能包含数字、字母、下划线
^\w{6,12}$
- 写一个正则表达式,匹配邮箱
[email protected]
^\w+@\w+(\.\w+){1,2}$
- 匹配一个座机号
xxx-xxxxxxxx
前面:1-3个数字
后面:4-8个数字
^\d{1,3}-\d{4,8}$
- 匹配一个正数
^\d+(\.\d+)?$
- 匹配一个小数
^-?\d+\.\d+$
^-?\d+(\.0+)?$
- 匹配一个整数
^-?\d+$
JS中的应用
js中,正则表达式表现为一个对象,该对象是通过构造函数RegExp
创建正则对象
- 字面量模式
- 构造函数模式
参考
var reg = /^-?\d+$/;//法一
var reg1 = new RegExp("^-?\d+$");//法二
RegExp("^-?\d+$");//法三 直接调用
var reg = /^-?\d+$/;
var reg1 = new RegExp(reg);//创建新的对象 reg1 !== reg
var reg2 = RegExp(reg);//reg2 === reg
正则实例成员
- global:是否开启全局匹配。针对字符串中所有可能的匹配项测试正则表达式,还是仅针对第一个匹配项。
- ignoreCase:匹配文本的时候是否忽略大小写。
- multiline:是否进行多行搜索。
- source:正则表达式的文本。规则字符串
- test方法:验证某个字符串是否满足规则
- exec方法:execute,执行匹配,得到匹配结果。
开启了全局匹配global,可移动,并且可以更改lastIndex的值
var reg = /^-?\d+(\.0+)?$/gmi;
console.log(reg.test("123")); //true
lastIndex :是正则表达式的一个可读可写的整型属性,用来指定下一次匹配的起始索引。
var reg = /abc/g;
console.log(reg.lastIndex,reg.test("111abc111abc111"));//0 true 位置到第一个abc
console.log(reg.lastIndex,reg.test(