正则表达式
- 用于定义一些字符串的规则
- 计算机可以根据正则表达式来检查一个字符串是否符合规则,获取将字符串中符合规则的内容提取出来
正则的使用场景
一般情况下,正则额都可以对需要某些规则下的字符进行匹配,从而得到用户输入的字符串是否为系统需要的格式
创建正则表达式的对象(直面量)
语法:
- let 变量=new RegExp(“正则表达式”,“匹配模式”);
例:let reg=new RegExp(“W3School”,“g”);
- 使用typeof检查正则对象,会返回object
- let result=new RegExp(“a”);//检查 一个字符串是否含有“a”
- 在构造函数中可以传递一个匹配模式作为第二个参数,如果符合则返回true,否则返回false
正则表达式的方法
test()
- 使用这个方法可以用来检查一个字符串是否符合正则表达式的规则,如果符合则返回true,否则返回false
使用字面量来创建正则表达式
语法:let 变量=/正则表达式/匹配模式
使用字面量创建更加简单,使用构造函数创建更加灵活
- reg=/a|b/; 使用“|”表示或者的意思,检查含a或b
- [nm…]中括号代表的是一个字符,可以匹配里边所有指定字符之一
- reg=/[ab]/; ===reg=/a|b/;
- reg=/[a-z]/; 任意小写字母
- reg=/[A-Z]/; 任意大写字母
- reg=/[A-z]/; 任意字母 === reg=/[A-z]/i;
- reg=/a[bde]c/; 含有abc或adc或aec
- reg=/[0-9]/; 任意数字
- x{n} 以大括号前的字符为标准匹配n个字符
- {n,m}匹配n到m个字符
- {n,}匹配最少n个字符
注意:正常情况下匹配多少个字符是能匹配多少匹配多少,这是正则表达式的贪婪模式也是默认的模式,如果在后面加上?就变成了非贪婪模式。
例;reg=/[0-9]{11}/ 连续的11位数字 - (xy) 小括号代表一个整体,也可以认为是节点,方便在匹配到的字符串中再进行分别的字符串提取
- 正则中也有特殊代表符
- \d 代表所有数字
- \w 代表所有英文
- . 代表所有非换行符和制表符以外的一个字符
- \n\r 代表是换行和回车符
- . 代表 .
- \\ 代表
注意:使用构造函数时,由于它的参数是一个字符串,而\是字符串转义字符,如果要使用\则需要使用\\来代替
let reg=new RegExp("\."); - 正则中也有特殊代表字符数量的代表符
- x+ 最少一个x字符等同于x{1,}
- x? 一个或零个字符,等同于x{0,1}
- x* 零个或多个字符,等同于x{0,}
- 正则中也有其他特殊作用的代表符
- ^X 指的是以x作为开头
- x$ 指的是以x结尾的字符串
----如果在正则表达式中同时使用^ $,则要求字符串必须完全符合正则表达式 - [^x] 匹配一个非x的字符
reg=/[^ab]/; 含除了ab以外
reg=/[^0-9]/; 除了数字以外
- 正则表达式修饰符:
1. i :执行不区分大小写的匹配
2. g :执行一个全局匹配,简言之,即找到所有的匹配
3. m :多行匹配模式,^匹配一行的开头和字符串的开头,$匹配行是结束和字符串的结束
正则表达式与字符串相关的方法
split()
- 可以将一个字符串拆分成一个数组
- 方法中可以传递一个正则表达式作为参数,这样方法将会根据正则表达式去拆分字符串
- 这个方法即使不指定全局匹配也会全部拆分
search()
- 可以搜索字符串中是否含有指定内容
- 如果搜索到指定内容,则会返回第一次出现的索引,如果没有搜索到则返回-1
- 它可以接受一个正则表达式作为参数,然后会根据正则表达式去检索字符串
- search只会查找第一个,即使设置全局匹配也没用
str="hello abc hello aec afc";
//字符串中是否含有abc或aec或afc
result=str.search(/a[bef]c/);
match()
- 可以根据正则表达式,从一个字符串中将符合条件的内容提取出来
- 默认情况下match只会找到第一个符合要求的内容,找到以后就会停止搜索,我们可以设置正则表达式为全局匹配模式,这样就能匹配到所有了(在正则表达式后边加上修饰符g),可以为一个正则表达式设置多个匹配模式,且顺序无所谓
- match会将匹配到的内容封装到一个数组中返回,即使只查询到一个结果
replace()
- 可以将字符串指定内容替换为新的内容
- 参数:
1,被替换的内容
2,新的内容(如果是空串就是删除)
-默认只替换第一个,我们可以设置正则表达式为全局匹配模式,这样就能匹配到所有了(在正则表达式后边加上修饰符g)