- 正则:就是用来操作字符串(匹配和捕获)的一系列规则;
- 匹配:校验字符串是否符合我们的规则; 返回值-》布尔值 true false;
- 匹配这里用的正则方法:test() reg.test();
- 捕获:把复合我们规则的内容拎出来; 返回值-》复合规则的字符串;
正则有两种创建方式:
1.字面量创建方式
2.实例创建方式
字面量和实例创建的区别:
1.字面量创建不能进行变量拼接,但是,实例创建可以进行变量拼接;
2.字面量创建方式,特殊含义的字符不需要转移,但是,实例创建需要转义(带\的);
正则由两部分组成:元字符+修饰符;
元字符包含:
- 代表特殊含义的元字符
\ 转义
| 或
() 分组
. 代表除了\n以外的其他字符;
\n 换行
\b 开头结尾和空格
^ 开头
$ 结尾
\s 空格 \d数字 \w 数字字母下划线
\S 非空格 \D非数字 \W 非数字字母下划线
[a-z] 字母 [^a-z]非字母
[abc]abc三个字母中的任何一个 [^abc]除了这三个字母中的任何一个字符 - 代表次数的量词元字符;
* 0到多
+ 1到多
? 0次或1次 可有可无的意思
{n} 正好n次;
{n,} n到多次
{n,m} n次到m次 - 修饰符 g 全局 i 忽略大小写 m换行;
中括号总结:
1)中括号中的字符没有特殊含义;(但是像\w还是有特殊含义的)
2)中括号中,不会出现两位数;
关于小括号:
1)提高优先级:凡是有|出现的时候,外面一定要加上()来提高优先级; /^(18|19)$/
2)分组
3)只匹配不捕获 (?:)
正则的捕获:
- exec:exec拿到的是个数组,一般情况下这个数组有三项:
1.符合大正则的内容
2.找到内容的索引
3.原始字符串; - match:
- replace:
replace的参数,拿到的是个数组:数组中一般情况下有三项:
1.符合大正则的内容
2.找到的内容对应的索引
3.原始字符串;
如果说,正则中有小分组的时候,小分组从数组的第二项开始;
正则捕获的特性:
- 懒惰性:
解决措施:全局g; - 贪婪性:
解决措施:在两次元字符后面加上?号;
正则的属性:
lastIndex:代表开始查找位置的索引;lastIndex是正则对象的一个属性:作用-》打印出开始查找的位置;(从找到内容的下一项内容的索引开始查找;)
lastIndex主要受两方面的影响:1)exec 2)test;
问号的用法:
- ? 量词元字符,代表可有可无
- +? 解决正则的贪婪性;
- (?:) 只匹配不捕获;
exec和match区别:
- 在全局g的情况下,每次只能拿到一个数组,但是,exec可以把符合正则内容字符串进行小分组的摘取;
- 在全局g的情况下,match能拿到符合正则内容的字符串的数组;但他没有小分组
正则的方法:
- reg.test() 校验-匹配的,返回的是布尔值
- reg.exec() 捕获-返回值数组,默认情况下,数组有三项,当有小分组的时候,小分组从第二项开始
- reg.lastIndex; 开始查找内容的位置的索引;
2.字符串方法: - match(); 把找到的符合正则的内容,以一个新数组的形式返回
- replace(); 可以通过arguments,拿到大正则和小分组,arguments的实现原理就是exec;
- split(reg);
- search(reg);
链式操作:核心就是前一个方法的返回值,返回的是个数组,就能使用数组的方法,返回的是个数字,只能使用数字的方法 - exec 可以封装match; 也是replace的实现原理;(replace中的arguments跟exec拿到的值是一模一样的)
网友评论