W3Cschool
恭喜您成為首批注冊用戶
獲得88經驗值獎勵
正則表達式(英語:Regular Expression,在代碼中常簡寫為regex、regexp或RE)使用單個字符串來描述、匹配一系列符合某個句法規(guī)則的字符串搜索模式。
搜索模式可用于文本搜索和文本替換。
正則表達式是由一個字符序列形成的搜索模式。
當你在文本中搜索數據時,你可以用搜索模式來描述你要查詢的內容。
正則表達式可以是一個簡單的字符,或一個更復雜的模式。
正則表達式可用于所有文本搜索和文本替換的操作。
實例解析:
/w3cschool/i 是一個正則表達式。
w3cschool 是一個模式 (用于檢索)。
i 是一個修飾符 (搜索不區(qū)分大小寫)。
在 JavaScript 中,正則表達式通常用于兩個字符串方法 : search() 和 replace()。
search() 方法 用于檢索字符串中指定的子字符串,或檢索與正則表達式相匹配的子字符串,并返回子字符串的起始位置。
replace() 方法 用于在字符串中用一些字符替換另一些字符,或替換一個與正則表達式匹配的子字符串。
使用正則表達式搜索 "w3cschool" 字符串,且不區(qū)分大小寫:
輸出結果為:
search 方法可使用字符串作為參數。字符串參數會轉換為正則表達式:
使用正則表達式且不區(qū)分大小寫將字符串中的 Microsoft 替換為 w3cschool :
結果輸出為:
replace() 方法將接收字符串作為參數:
正則表達式參數可用在以上方法中 (替代字符串參數)。
正則表達式使得搜索功能更加強大(如實例中不區(qū)分大小寫)。 |
修飾符 可以在全局搜索中不區(qū)分大小寫:
修飾符 | 描述 |
---|---|
i | 執(zhí)行對大小寫不敏感的匹配。 |
g | 執(zhí)行全局匹配(查找所有匹配而非在找到第一個匹配后停止)。 |
m | 執(zhí)行多行匹配。 |
方括號用于查找某個范圍內的字符:
表達式 | 描述 |
---|---|
[abc] | 查找方括號之間的任何字符。 |
[0-9] | 查找任何從 0 至 9 的數字。 |
(x|y) | 查找任何以 | 分隔的選項。 |
元字符是擁有特殊含義的字符:
元字符 | 描述 |
---|---|
\d | 查找數字。 |
\s | 查找空白字符。 |
\b | 匹配單詞邊界。 |
\uxxxx | 查找以十六進制數 xxxx 規(guī)定的 Unicode 字符。 |
量詞:
量詞 | 描述 |
---|---|
n+ | 匹配任何包含至少一個 n 的字符串。 |
n* | 匹配任何包含零個或多個 n 的字符串。 |
n? | 匹配任何包含零個或一個 n 的字符串。 |
在 JavaScript 中,RegExp 對象是一個預定義了屬性和方法的正則表達式對象。
test() 方法是一個正則表達式方法。
test() 方法用于檢測一個字符串是否匹配某個模式,如果字符串中含有匹配的文本,則返回 true,否則返回 false。
以下實例用于搜索字符串中的字符 "e":
字符串中含有 "e",所以該實例輸出為:
你可以不用設置正則表達式的變量,以上兩行代碼可以合并為一行:
exec() 方法是一個正則表達式方法。
exec() 方法用于檢索字符串中的正則表達式的匹配。
該函數返回一個數組,其中存放匹配的結果。如果未找到匹配,則返回值為 null。
以下實例用于搜索字符串中的字母 "e":
compile() 方法用于改變 RegExp。
compile() 既可以改變檢索模式,也可以添加或刪除第二個參數。
由于字符串中存在 "e",而沒有 "d",以上代碼的輸出是:
完整的 RegExp 對象參考手冊,請參考我們的 JavaScript RegExp 參考手冊。
該參考手冊包含了所有 RegExp 對象的方法和屬性。
如果你想知道有哪些js常用的正則表達式,請參考 js 實戰(zhàn)手冊。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯系方式:
更多建議: