Appearance
正则
正则表达式用于定义一些字符串的规则:
计算机可以根据正则表达式,来检查一个字符串是否符合规则 *获取将字符串中符合规则的内容提取出来。
创建正则表达式
var reg = new RegExp("正则","匹配模式");//参数是字符串,可以写变量;构造函数创建更加灵活
var reg = /正则表达式/匹配模式 //参数不需要加引号;创建更加简单 遇到\转义,通过new创建,因为里面参数是字符串,要先\转义成对应要的正则表达式,再把正则表达式\转义成实际代表的字符串
字符串和正则相关的方法
split(""),参数可以是正则表达式,split方法返回一个数组
search()
- 可以搜索字符串中是否含有指定内容
- 如果搜索到指定内容,则会返回第一次出现的索引,如果没有搜索到返回-1
- 它可以接受一个正则表达式作为参数,然后会根据正则表达式去检索字符串
- search()只会查找第一个,即使设置全局匹配也没用
jsstr = "hello abc hello aec afc"; /* * 搜索字符串中是否含有abc 或 aec 或 afc */ result = str.search(/a[bef]c/); //console.log(result); ``
str = "hello abc hello aec afc"; /* * 搜索字符串中是否含有abc 或 aec 或 afc */ result = str.search(/a[bef]c/); //console.log(result); ``
match()
- 可以根据正则表达式,从一个字符串中将符合条件的内容提取出来
- 默认情况下我们的match只会找到第一个符合要求的内容,找到以后就停止检索
- 我们可以设置正则表达式为全局匹配模式,这样就会匹配到所有的内容
- 可以为一个正则表达式设置多个匹配模式,且顺序无所谓
- match()会将匹配到的内容封装到一个数组中返回,即使只查询到一个结果
jsstr = "1a2a3a4a5e6f7A8B9C"; result = str.match(/[a-z]/ig); //console.log(result[2]);
str = "1a2a3a4a5e6f7A8B9C"; result = str.match(/[a-z]/ig); //console.log(result[2]);
replace()
- 可以将字符串中指定内容替换为新的内容
- 参数:
- 被替换的内容,可以接受一个正则表达式作为参数
- 新的内容
- 默认只会替换第一个
js//result = str.replace(/[a-z]/gi , "@_@"); result = str.replace(/[a-z]/gi , ""); //console.log(result);
//result = str.replace(/[a-z]/gi , "@_@"); result = str.replace(/[a-z]/gi , ""); //console.log(result);
语法:
匹配模式:
i:忽略大小写
g:全局匹配模式设置匹配模式时,可以都不设置,也可以设置1个,也可以全设置,设置时没有顺序要求
方法: test()
- 可以用来检查一个字符串是否符合正则表达式
- 如果符合返回true,否则返回false
正则语法
语法
| 或
[] 或
[^ ] 除了
[a-z] 小写字母
[A-Z] 大写字母
[A-z] 任意字母
[0-9] 任意数字量词 {n} 正好n次
{m,n} m-n次
{m,} 至少m次
+ 至少1次 {1,}
? 0次或1次 {0,1}
* 0次或多次转义字符 \ 在正则表达式中使用\作为转义字符
\.
表示.\\
表示\.
表示任意字符
\w 相当于[A-z0-9_]
\W 相当于[^A-z0-9_]
\d 任意数字
\D 除了数字
\s 空格
\s+ 单个的空白字符,换行符也算单个的空白字符
\S 除了空格
\b 单词边界****
\B 除了单词边界^ 表示开始
$ 表示结束