RegExp 正则
正则,就是一条规则,用于检验字符串的格式,目标就是字符串。
正则的定义
1.var reg=new RegExp();
2.var reg=/格式/;
正则的方法
两大功能,一个是匹配,匹配成功就是true,第二个是捕获,如果有就拿出来。
test()用于匹配
exec()用于捕获
正则的修饰符
1.区不区分大小写 i 代表忽略大小写
2.全局 g 代表全局匹配
3.m 代表多行匹配
用法1.var reg=new RegExp("hello",g)
2.var reg=/hello/gi
字符串方法中跟正则有关的
1.match()查找一个或多个与正则相匹配的 有就返回的是查找的结果,没有就是null
2.search()匹配和正则相同的字符,有就返回索引,没有就是-1
3.replace()匹配和正则相同的,并替换掉,返回的是替换后的字符串
正则的方括号
[abc] 代表查找方括号中的任何字符
[^abc] 代表查找任何一个不在方括号之间的字符
[0-9] 查找0-9之间的数字
[a-z] 查找任何小写a到小写z的字符
[A-Z] 查找任何大写A到大写Z的字符
[A-z] 查找大写A到小写z的字符
(red|blue|green)
元字符
.代表单个字符
\w代表单词字符 数字 字母 _
\W代表非单词字符
\d代表数字
\D代表非数字
\s代表空白字符
\S代表非空白字符
\b代表单词边界
\B代表非单词边界
量词
1.n+ 代表至少1个n的字符
2.n* 代表0个或多个n
3.n?包含0个或1个n
4.n{x} 包含x个n
5.n{x,}包含至少x个n
6.n{x,y}包含大于等于x个小于等于y个n
7.n$ 包含以n结尾的字符串
8.^n 包含以n开头的字符串
9.?=n 指定字符串后面紧跟的n的字符串
正则的理解
1.正则的懒惰性
每一次在exec()中捕获的时候,只捕获第一次匹配的内容,而不往下捕获了。我们把这叫正则的懒惰性,每一次捕获的开始位置都是从0开始
解决方法:
使用修饰符g
2.正则的贪婪性
每一次匹配都是按照最长的出结果,我们把这种功能叫正则的贪婪性。
解决方法
在元字符量词后面加?
正则的分组捕获
: 正则带() 在数分组的个数是从左往右
列:var reg=/(a)(b)/ 就相当于大正则里面带了俩个小正则
分组的捕获前提是正则存在分组,不仅把大正则的内容捕获到,把小正则的内容也捕获到。
分组捕获的作用
1.改变优先级
2.分组引用
var reg=/(\w)\1(\w)\2/
var st="ssdd"
var s=reg.test(st)
console.log(s)
\2代表和第二个分组出现一模一样的内容,\1代表和第一个分组出现一模一样的内容
Reg中的规则是第一个是一个分组 且是一个单词字符 第二个是个分组引用要求和第一组一模一样,第三个是第二个分组且是一个单词字符,第四个是一个分组引用,要求和第二组一模一样。
怎样解除分组中分组捕获呢?
如果你不想捕获某一个分组中的内容,在这个分组的前面加上?:就可以了