一、概述
正则表达式(Regular Expression)是一个描述字符模式的对象, 用于对字符串进行匹配, 一般用在有规律的字符串匹配中;常用于表单验证以及相关的字符串匹配
二、声明
1.使用正则表达式直接量,将其包含在一对斜杠(/)之间的字符。
var regx = /a/ //表示匹配a
//字符串支持正则的方法 replace split search match
var str = 'abcdef'
console.log(str.match(regx));
regx = /a/i
console.log('ABC'.match(regx));
2.使用new关键词来声明
//使用new关键词 参数一是匹配的对应的正则表达式 参数二模式
//i表示不区分大小写 g表示全局搜索
var regx1 = new RegExp('a','i')
var str1 = 'ABC'
console.log(str1.match(regx1));
模式修饰
g 全局搜索
i 不区分大小写
m 换行模式
三、正则匹配的元字符
[] 表示里面任意的一个元素
^ 表示开头
$ 表示结尾
{} 表示个数
var regx2 = /[a-z]{6}/ //表示6个小写的字母
regx2 = /[a-z]{0}/ //表示0个字母
regx2 = /[a-z]{1,3}/ //表示1个到3个
regx2 = /[a-z]{1,}/ //表示1个到无穷个
{n,m} 匹配前一项至少n次,至多m次
{n,} 匹配前一项n次或者更多次,也可以说至少n次
{n} 匹配前一项n次
? 匹配前一项0次或者1次,等价于{0,1}
+ 匹配前一项1次或多次,等价于{1,}
* 匹配前一项0次或多次,等价于{0,}
注意:在使用“”和“?”时,由于这些字符可能匹配0个字符,因此它们允许什么都不匹配。比如:正则表达式/a/实际上与字符 串“bbb”匹配,因为这个字符串含有0个a。
.
表示所有的内容(包括中文字符)
\w 表示对应的字母数字下滑线 \W 就是相反的 不是字母数字下滑线
\d 表示数字 \D表示非数字
\s 表示空白字符串(回车 制表 空格) \S就是相反的 不是空白字符
() 分组
| 或者
转义 \
//匹配 ? * + .等元字符 转义\
var regx10 = /^[?]$/
console.log('?'.match(regx10));
var regx10 = /^[*]$/
console.log('*'.match(regx10));
//用转义字符来
var regx10 = /^\*$/
console.log('*'.match(regx10));
var regx10 = /^\.$/
console.log('.'.match(regx10));
四、检测方法
test
正则对象的test方法返回一个布尔值,表示当前模式是否能匹配参数字符串。
var regx = /\w/
console.log(regx.test('abc')) //true
注意:如果正则表达式带有g修饰符,则每一次test方法都从上一次结束的位置开始向后匹配,也可以通过正则对象的 lastIndex属性指定开始搜索的位置。
exec
正则对象的exec方法,可以返回匹配结果。如果发现匹配,就返回一个数组,成员是每一个匹配成功的子字符串,否则返回 null。
var regx = /\d/
console.log(regx.exec('123')) //[1,2,3]
五、字符串支持正则的4个方法
- split :按照给定规则进行字符串分割,返回一个数组,包含分割后的各个成员。
- replace :按照给定的正则表达式进行替换,返回替换后的字符串。
- search :按照给定的正则表达式进行搜索,返回一个整数,表示第一个与之匹配的字符串的起始位置,如果找不到匹配 的子串,将返回-1。
- macth:返回一个数组,成员是所有匹配的子字符串。
search()
按照给定的正则表达式进行搜索,返回一个整数,表示第一个与之匹配的字符串的起始位置,如果找不到匹配的子串,将返 回-1。
"javascript".search(/script/i);
//上面的代码的返回值为4
如果search()的参数不是正则表达式,则首先会通过RegExp构造函数将它转换成正则表达式,search()方法不支持全局检索, 因为它忽略正则表达式参数中的修饰符g。
match()
match()方法的唯一参数是一个正则表达式,返回的是一个由匹配结果组成的数组。如果该正则表达式设置了修饰符g,则返 回的数组包含字符串中的所有匹配结果。
'1 plus 2 equals 3'.match(/\d+/g) //返回["1","2","3"]
返回来的数组还带有另外两个属性:index和input,分别表示包含发生匹配的字符位置和引用的正在检索的字符串。
replace()
replace()方法用以执行检索与替换操作。其中第一个参数是一个正则表达式,第二个参数是要进行替换的字符串。
如果replace()的第一个参数是字符串而不是正则表达式,则replace()将直接搜索这个字符串,而不会像search()一样首先通过 RegExp()将它转换为正则表达式。
replace方法的第二个参数可以使用美元符号$,用来指代所替换的内容
$` 指代匹配结果前面的文本。
$' 指代匹配结果后面的文本。
$n 指代匹配成功的第n组内容,n是从1开始的自然数。
$$ 指代美元符号$。
比如:
// "world hello"
replace方法的第二个参数还可以是一个函数,将每一个匹配内容替换为函数返回值。
'abca'.replace(/a/g,function(match){ return match.toUpperCase(); });
// "AbcA"
replace()方法的第二个参数可以接受多个参数。第一个参数是捕捉到的内容,第二个参数是捕捉到的组匹配(有多少个组匹 配,就有多少个对应的参数)。
split()
split()方法用以将调用它的字符串拆分为一个子串组成的数组。 ```
'123,456,789'.split(',')
//返回["123","456","789"]
split()方法的参数也可以是一个正则表达式。
网友评论