文章目录
- 正则表达式
- 正则表达式标志
- string.match()
-
- [.test() vs .match()](#.test() vs .match())
- [正则 []](#正则 [])
- 标识符
- 非捕获组
正则表达式
正则表达式通常简称为 "regex" 或 "regexp",是帮助程序员匹配、搜索和替换文本的模式。正则表达式功能强大,使用了大量特殊字符。
正则表达式标志
i 表达式忽略大小写
g 全局匹配 (Global),查找所有匹配项,而不是在找到第一个匹配项后就停止。
const helpRegex = /please help/i; 与字符串 please help 匹配的正则表达式,忽略大小写
msg.match(helpRegx); //
helpRegex.test(msg); // return bool
string.match()
字符串有一个 .match() 方法,它接受正则表达式作为参数并确定字符串是否与该表达式匹配。
.test() vs .match()
.test() 与.match()不同,.test() 返回一个布尔值,指示字符串是否与模式匹配。
.filter()
.some() 接受一个回调函数,该函数应将数组中的一个元素作为参数。如果回调函数对数组中的至少一个元素返回true,.some() 方法将返回true。
const arr = ["A", "b", "C"];
arr.some(letter => letter === letter.toUpperCase());
const helpRegex = /please help|assist me/i; // 正则表达式
const denyList = [helpRegex];
const isSpam = (msg) => helpRegex.test(msg); // .test()
const isSpam = (msg) => denyList.some(regex => regex.test(msg)); //.some()
正则 []
\] 匹配里面的内容 /a+/ +出现1次多无数次 用 (a\|b\|c) 匹配 多个单词选项(如 hundred或 thousand)。 用 \[abc\] 匹配 单个字符选项(如 \[a-z\]匹配任意小写字母)。 ## 标识符 ? 匹配前面字符或组的零次或一次出现。 用 \\s\* 表达式替换第一个文字空格。 \\s 字符类匹配空白,例如空格、制表符和换行符。 \* 量词表示"匹配前一个字符 0 次或更多次"。 ## 非捕获组 实际上并不需要捕获组中的匹配值,因此你可以将其转换为非捕获组。 这将允许你将字符组合在一起而不保留结果。 要在正则表达式中创建非捕获组,可以在组的左括号后添加 ?:。 例如,(?:a\|b) 将匹配 a 或 b,但不会捕获结果。