簡述JS正則RegExp物件
阿新 • • 發佈:2021-10-14
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
本文來自部落格園,作者:吳知木,轉載請註明原文連結:https://www.cnblogs.com/zh1q1/p/15405398.html