正则表达式:规定了字符串中字符出现规律的表达式
正则表达式的pattern(模式)可以时任何简单或复杂的正则表达式,包括字符类、限定符、分组、向前查找和反向引用。每个正则表达式可以带零个或多个flags(标记),用于控制正则表达式的行为
下面给出了表示匹配模式的标记:
- g:全局模式,表示查找字符串的全部内容,而不是找到第一个匹配的内容就结束
- i:不区分大小写,表示在查找匹配时忽略pattern和字符串的大小写
- m:多行模式,表示查找到一行文本末尾时会继续查找
- y:粘附模式,表示只查找从lastlndex开始及以后的字符串
- u:Unicode模式,启用Unicode匹配
- s:dotAll模式,表示元字符,匹配任何字符(包括\n或\r)
使用不同模式和标记可以创建出各种正则表达式:
// 匹配字符串中的所有"at"
let pattern1 = /at/g
// 匹配第一个"bat"或"cat",忽略大小写
let pattern2 = /[bc]at/i;
// 匹配所有以"at"结尾的三字符组合,忽略大小写
let pattern3 = /.at/gi;
这里的 pattern1 匹配”bat”或”cat”,不区分大小写。要直接匹配”[bc]at”,左右中括号都必 须像 pattern2 中那样使用反斜杠转义。在 pattern3 中,点号表示”at”前面的任意字符都可以匹配。 如果想匹配”.at”,那么要像 pattern4 中那样对点号进行转义。
创建 RegExp 对象的语法
//var 变量 = new RegExp("正则表达式","匹配模式")
let search = new Regexp(/a/,"g"); //g表示全局搜索,此为全局搜索带a的字符串
使用字面量创建正则表达式
// let 变量 = /正则表达式/匹配模式
let search = /a/g // g 表示全局搜索
let srt = "hellw word"
let reg = /l/ig // i 忽略大小写 g 全局替换
console.log(srt.replace(reg,"*")); // "he**w word"
//将检索到的“l”和“L”全部都换成“*”
rest()
检测正则表达式是否匹配字符串的一部分,返回布尔值(Boolean) 如果输入的文本与模式匹配,则参数返回true,否则返回false。这个方法适用于只想测试模式是否匹配,而不需要实际匹配内容的情况
reg.test(str);
let reg = /abc/;
let str = "adcbf",
otherStr = "acabcf";
console.log(reg.test(str)); //false 字符串中没有"abc"
console.log(reg.test(otherStr))//true
test()经常在if语句中:
let text = "000-00-0000";
let pattern = /\d{3}-\d{2}-\d{4}/;
if (pattern.test(text)) {
console.log("The pattern was matched.");
}
- 在这个例子中,正则表达式用于测试特定的数值序列
- 如果输入的文本与模式匹配,则显示匹配成功的消息
- 这个用法常用于验证用于输入,此时我们只在乎输入是否有效,不关心问什么无效。
注意 正则表达式的 valueOf()方法返回正则表达式本身。