RegExp對象
正則表達式是描述字符模式的對象。
正則表達式用於對字符串模式匹配及檢索替換,是對字符串執行模式匹配的強大工具。
語法
定義
當使用 構造函數 創造正則對象時,需要常規的字符轉義規則(在前面加反斜杠 \)
/* 比如,以下兩種方式的定義是等價的 */
// 構造函數方式
const reg = new RegExp("\\w+");
// 字面量方式
const reg = /\w+/;
修飾符
用於執行區分大小寫和全局匹配
修飾符 描述
i 執行對大小寫不敏感的匹配。
g 執行全局匹配(查找所有匹配而非在找到第一個匹配后停止)。
m 執行多行匹配。
/* 栗子 */
const reg = /\w/gi
方括號
用於查找某個范圍內的字符:
表達式 描述
[abc] 查找方括號之間的任何字符。
[^abc] 查找任何不在方括號之間的字符。
[0-9] 查找任何從 0 至 9 的數字。
[a-z] 查找任何從小寫 a 到小寫 z 的字符。
[A-Z] 查找任何從大寫 A 到大寫 Z 的字符。
[A-z] 查找任何從大寫 A 到小寫 z 的字符。
[adgk] 查找給定集合內的任何字符。
[^adgk] 查找給定集合外的任何字符。
(red|blue|green) 查找任何指定的選項。
/* 栗子 */
const reg = /[0-9]/g
元字符
是擁有特殊含義的字符:
元字符 描述
. 查找單個字符,除了換行和行結束符。
\w 查找單詞字符。
\W 查找非單詞字符。
\d 查找數字。
\D 查找非數字字符。
\s 查找空白字符。
\S 查找非空白字符。
\b 匹配單詞邊界。
\B 匹配非單詞邊界。
\0 查找 NUL 字符。
\n 查找換行符。
\f 查找換頁符。
\r 查找回車符。
\t 查找制表符。
\v 查找垂直制表符。
/* 栗子 */
const reg = /\d/g // 匹配數字
量詞
是擁有特殊含義的字符:
量詞 描述
n+ 匹配任何包含至少一個 n 的字符串。
n* 匹配任何包含零個或多個 n 的字符串。
n? 匹配任何包含零個或一個 n 的字符串。
n{X} 匹配包含 X 個 n 的序列的字符串。
n{X,Y} 匹配包含 X 至 Y 個 n 的序列的字符串。
n{X,} 匹配包含至少 X 個 n 的序列的字符串。
n$ 匹配任何結尾為 n 的字符串。
^n 匹配任何開頭為 n 的字符串。
?=n 匹配任何其后緊接指定字符串 n 的字符串。
?!n 匹配任何其后沒有緊接指定字符串 n 的字符串。
/* 栗子 */
const reg = /\d+/g // 匹配至少一個數字
方法
是擁有特殊含義的字符:
方法 描述
compile 編譯正則表達式。
exec 檢索字符串中指定的值。返回找到的值,並確定其位置。
test 檢索字符串中指定的值。返回 true 或 false。
search 檢索與正則表達式相匹配的值。返回首次出現的位置,沒有則為-1。
match 找到一個或多個正則表達式的匹配。
replace 替換與正則表達式匹配的子串。
split 把字符串分割為字符串數組。
/* 栗子 */
var patt = /Hello/g
var result = patt.test(str) // 查找Hello字串 -> true