什么是 RegExp?
RegExp 是正則表達(dá)式的縮寫。
當(dāng)您檢索某個文本時,可以使用一種模式來描述要檢索的內(nèi)容。RegExp 就是這種模式。
簡單的模式可以是一個單獨(dú)的字符。
更復(fù)雜的模式包括了更多的字符,并可用于解析、格式檢查、替換等等。
您可以規(guī)定字符串中的檢索位置,以及要檢索的字符類型,等等。
定義 RegExp
const pattern = new RegExp('str');
RegExp 對象的方法
- test()
- exec()
- compile()
test() 方法檢索字符串中的指定值。返回值是 true 或 false。
const pattern = new RegExp('str');
console.log(pattern.test('input string')); // true
exec() 方法檢索字符串中的指定值。返回值是被找到的值。如果沒有發(fā)現(xiàn)匹配,則返回 null。
const pattern = new RegExp('str');
console.log(pattern.test('input string')); // [ 'str', index: 6, input: 'input string', groups: undefined ]
compile() 方法用于改變 RegExp(既可以改變檢索模式,也可以添加或刪除第二個參數(shù))。
const pattern = new RegExp('e');
console.log(pattern.test('The best things in life are free'));
pattern.compile('d');
console.log(pattern.test('The best things in life are free'));
支持正則表達(dá)式的 String 對象的方法
- search()
- match()
- replace()
- split()
search()方法檢索與正則表達(dá)式相匹配的子字符串。search() 方法不執(zhí)行全局匹配,它將忽略標(biāo)志 g。它同時忽略 regexp 的 lastIndex 屬性,并且總是從字符串的開始進(jìn)行檢索,這意味著它總是返回 stringObject 的第一個匹配的位置。
// stringObject.search(regexp) 語法 (匹配不上時返回 -1)
const stringObj = 'Hello world';
const result = stringObj.search(/l{3}/);
console.log(result); // -1
match() 方法可在字符串內(nèi)檢索指定的值,或找到一個或多個正則表達(dá)式的匹配。該方法類似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。
// stringObject.match(regexp) 語法 (匹配不上時返回 null)
const stringObj = 'Hello world';
const result = stringObj.match(/l{2}/);
console.log(result); // [ 'll', index: 2, input: 'Hello world', groups: undefined ]
replace() 方法用于在字符串中用一些字符替換另一些字符,或替換一個與正則表達(dá)式匹配的子串。
字符串 stringObject 的 replace() 方法執(zhí)行的是查找并替換的操作。它將在 stringObject 中查找與 regexp 相匹配的子字符串,然后用 replacement 來替換這些子串。如果 regexp 具有全局標(biāo)志 g,那么 replace() 方法將替換所有匹配的子串。否則,它只替換第一個匹配子串。
// stringObject.replace(regexp/substr,replacement) 語法 (匹配不上時返回原字符串)
const stringObj = 'Hello world';
const result = stringObj.replace(/l{2}/,'ii');
console.log(result); // Heiio world
split() 方法用于把一個字符串分割成字符串?dāng)?shù)組。
返回一個字符串?dāng)?shù)組。該數(shù)組是通過在 separator 指定的邊界處將字符串 stringObject 分割成子串創(chuàng)建的。返回的數(shù)組中的字串不包括 separator 自身。
但是,如果 separator 是包含子表達(dá)式的正則表達(dá)式,那么返回的數(shù)組中包括與這些子表達(dá)式匹配的字串(但不包括與整個正則表達(dá)式匹配的文本)。
// stringObject.split(separator,howmany) 語法 (匹配不上時返回 [stringObject])
const stringObj = 'Hello world';
const result = stringObj.split(/l{2}/);
console.log(result) // [ 'He', 'o world' ]
RegExp 參數(shù)
- 直接量語法
/pattern/attributes
- 創(chuàng)建 RegExp 對象的語法
new RegExp(pattern, attributes);
參數(shù) pattern 是一個字符串,指定了正則表達(dá)式的模式或其他正則表達(dá)式。
參數(shù) attributes 是一個可選的字符串,包含屬性 "g"、"i" 和 "m",分別用于指定全局匹配、區(qū)分大小寫的匹配和多行匹配。ECMAScript 標(biāo)準(zhǔn)化之前,不支持 m 屬性。如果 pattern 是正則表達(dá)式,而不是字符串,則必須省略該參數(shù)。
注意
const reg = /str/;
const newReg = reg.compile(reg, 'i'); // 報錯
console.log(newReg.test('string'))
// 正確示例
const reg = /str/;
const newReg = new RegExp(reg, 'i');
console.log(newReg.test('string'));
附表
- 修飾符
| 修飾符 | 描述 |
|---|---|
| i | 執(zhí)行對大小寫不敏感的匹配。 |
| g | 執(zhí)行全局匹配 |
| m | 執(zhí)行多行匹配 |
- 方括號
| 表達(dá)式 | 描述 |
|---|---|
| [abc] | 查找方括號之間的任何字符 |
| [^abc] | 查找任何不在方括號之間的任何字符 |
| [0-9] | 查找任何從0至9的數(shù)字 |
| [a-z] | 查找任何從小寫a至小寫z的字符 |
| [A-Z] | 查找任何從大寫A至大寫Z的字符 |
| [A-z] | 查找任何從大寫A至小寫z的字符 |
| [adgk] | 查找給定集合內(nèi)的任何字符 |
| [^adgk] | 查找給定集合外的任何字符 |
| (red|blue|green) | 查找任何指定的選項 |
- 元字符
| 元字符 | 描述 |
|---|---|
| . | 查找單個字符,除了換行和行結(jié)束符。 |
| \w | 查找單詞字符。 |
| \W | 查找非單詞字符。 |
| \d | 查找數(shù)字字符。 |
| \D | 查找非數(shù)字字符。 |
| \s | 查找空白字符。 |
| \S | 查找非空白字符。 |
| \b | 匹配單詞邊界。 |
| \B | 匹配非單詞邊界。 |
| \0 | 查找 NUL 字符。 |
| \n | 查找換行符。 |
| \f | 查找換頁符。 |
| \r | 查找回車符。 |
| \t | 查找制表符。 |
| \v | 查找垂直制表符。 |
| \xxx | 查找以八進(jìn)制數(shù) xxx 規(guī)定的字符。 |
| \xdd | 查找以十六進(jìn)制數(shù) dd 規(guī)定的字符。 |
| \uxxxx | 查找以十六進(jìn)制數(shù) xxxx 規(guī)定的 Unicode 字符。 |
- 量詞
| 元字符 | 描述 |
|---|---|
| n+ | 匹配任何包含至少一個 n 的字符串。 |
| n* | 匹配任何包含零個或多個 n 的字符串。 |
| n? | 匹配任何包含零個或一個 n 的字符串。 |
| n{X} | 匹配包含 X 個 n 的序列的字符串。 |
| n{X,Y} | 匹配包含 X 至 Y 個 n 的序列的字符串。 |
| n{X,} | 匹配包含至少 X 個 n 的序列的字符串。 |
| n$ | 匹配任何結(jié)尾為 n 的字符串。 |
| ^n | 匹配任何開頭為 n 的字符串。 |
| ?=n | 匹配任何其后緊接指定字符串 n 的字符串。 |
| ?!n | 匹配任何其后沒有緊接指定字符串 n 的字符串。 |