正则 RegExp
正则 就是一条规则,用于检验字符串的格式,目标就是字符串
只要是表单提交的数据都是字符串。
定义:
1.var reg=new RegExp();
2.var reg=/格式/;
方法:
两大功能
一个是匹配,匹配成功就是true,第二个是捕获,如果有就拿出来
test() 用于匹配
Exec() 用于捕获
正则研究的对象是string
修饰符:如果去匹配
1.区不区分大小写 i代表忽略大小写
2.全局 g代表全局匹配
3.m代表多行匹配
怎么使用?
1.var reg=new RegExp("hello",g)
2.var reg=/格式/;
二者最后的本质都是一个对象
字符串的方法
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|bule|green)
元字符
.代表单个字符
w代表单词字符 数字 字母 _
W代表非单词字符
d代表数字
D代表非数字
s 代表空白字符
S代表非空白字符
代表单词边界
B代表非单词边界
量词
n+代表至少1个n的字符
n*代表0个或多个n
n?包含0个或1个
n{x}包含x个n
n{x,}包含至少x个n
n{x,y}包含大于x个小于y个
n$包含n结尾的字符串
^n包含以n开头的字符串
?=n指定的字符串后面紧跟的n字符串
正则的理解
1.正则的懒惰性
每一个在exec()中捕获的时候,只捕获第一次匹配的内容,而不往下捕获了。我们把这叫做正则的懒惰性,第一次捕获的开始位置都是从0开始
怎么解决正则的懒惰性呢?在后面加修饰符g
正则的实例对象reg上有一个lastIndex属性 它是正则捕获的起始位置
2.正则的贪婪性
每一次匹配都是按照最长的出结果,我们把这个功能叫正则的贪婪性
怎么解决正则的贪婪性?在元字符量词后面加?
分组捕获 正则带() 在数分组的个数是从从左往右
var reg=/(a)(b)/ 就相当于大正则里面带了两个小正则
第一组是(a) 第二组是(b)
分组捕获的作用:
1.改变优先级
2.分组引用 1,2
2代表和第二个分组出现一模一样的内容,1代表和第一个分组出现一模一样的内容
3.分组捕获
分组捕获前提是正则存在分组,不仅把大正则的内容捕获到,把小正则的内容也捕获到。
怎么解除分组中的分组捕获?如果不想捕获某一个分组中的内容,在这个分组前面加上?:就可以了。