1 \ 指出接着的字符為特殊字符。
例如:/b/匹配字符“b”,通過在b前面加一個反斜杠\,也就是/\b/,則該字符變成特殊字符,表示匹配一個單詞的分界線
2 ^ 表示匹配的字符必須在最前邊。
例如:/^A/ 不匹配“an A”中的“A”,但匹配“An A”中最前面的“A”
3 $
與^類似,匹配最末的字符。
例如:/t$/不匹配“eater”中的“t”,但匹配“eat”中的“t”
4 *
匹配*前面的字符0次或n次。
例如:/bo*/匹配“A ghost booooed”中的“boooo”或“A bird warbled”中的“b”,但不匹配“A goat grunted”中的任何字符
5 +
匹配+號前面的字符1次或n次。等價於{1,}。
例如:/a+/匹配“candy”中的“a”和“caaaaaaandy”中的所有“a”
6 ?
匹配?前面的字符0次或1次。
例如:/e?le?/匹配“angel”中的“el”和“angle”中的“le”
7 .
(小數點)匹配除換行符外的所有單個的字符。
例如:/.n/匹配“nay, an apple is on the tree”中的“an”和“on”,但不匹配“nay”
8 (x)
匹配'x'並記錄匹配的值。
例如:/(foo)/匹配和記錄“foo bar”中的“foo”。匹配子串能被結果數組中的元素[1], ..., [n]返回,或被RegExp對象的屬性$1, ..., $9返回
9 x|y
匹配“x”或者“y”。例如:/green|red/匹配“green apple”中的“green”和“red apple”中的“'red”
10 {n}
這里的n是一個正整數。匹配前面的n個字符。例如:/a{2}/不匹配“candy”中的“a”,但匹配“caandy”中的所有“a” 和“caaandy”中前面的兩個“a”
11 {n,}
這里的n是一個正整數。匹配至少n個前面的字符。例如:/a{2,}不匹配“candy”中的“a”,但匹配“caandy”中的所有“a”和“caaaaaaandy”中的所有“a”
12 {n,m}
這里的n和m都是正整數。匹配至少n個最多m個前面的字符。
例如:/a{1,3}/不匹配“cndy”中的任何字符,但匹配“candy”中的“a”,“caandy”中的前面兩個“a”和“caaaaaaandy”中前面的3個“a”,注意:即使“caaaaaaandy”中有很多個“a”,但只匹配前面的3個“a”即“aaa”
13 [xyz]
字符列表,匹配列出中的任意字符。可以通過連字符-指出一個字符范圍。
例如:[abcd]跟[a-c]一樣。它們匹配“brisket”中的“b”和“che”中的“c”
14 [^xyz]
字符補集,匹配除了列出的字符外的所有東西。可以使用連字符-指出一個字符范圍。
例如:[^abc]和[^a-c]等價,它們最早匹配“brisket”中的“r”和“chop”中的“h”
15 [\b]
匹配一個空格(不要與\b混淆)
16 \b
匹配一個單詞的分界線,比如一個空格(不要與[\b]混淆)。
例如:/\bn\w/匹配“noonday”中的“no”,/\wy\b/匹配“possibly yesterday”中的“ly”
17 \B
匹配一個單詞的非分界線。
例如:/\w\Bn/匹配“noonday”中的“on”,/y\B\w/匹配“possibly yesterday”中的“ye”
18 \cX
X是一個控制字符。匹配一個字符串的控制字符。
例如:/\cM/匹配一個字符串中的control-M
19 \d
匹配一個數字,等價於[0-9]。
例如:/\d/或/[0-9]/匹配“B2 is the suite number”中的“2”
20 \D
匹配任何非數字,等價於[^0-9]。
例如:/\D/或/[^0-9]/匹配“B2 is the suite number”中的“B”
21 \f
匹配一個表單符
22 \n
匹配一個換行符
23 \r
匹配一個回車符
24 \s
匹配一個white空格符,包括空格,tab,form feed,換行符,等價於[ \f\n\r\t\v]。
例如:/\s\w*/匹配“foo bar”中的“ bar”
25 \S
匹配一個制表符
26 \v
匹配一個頂頭制表符
27 \t
匹配一個制表符
28 \w
匹配所有的數字和字母以及下划線,等價於[A-Za-z0-9_]。
例如:/\w/匹配“apple”中的'a',“$5.28”中的“5”和“3D”中的“3”
29 \W
匹配除數字、字母外及下划線外的其他字符,等價於[^A-Za-z0-9_]。
例如:/\W/或者/[^$A-Za-z0-9_]/匹配“50%”中的“%”
30 \n
這里的n是一個正整數。匹配一個正則表達式最后一個子串的n的值(計數左圓括號)。
例如:/apple(,)\sorange\1/匹配“apple, orange, cherry, peach”中的“apple, orange”。注意:如果左圓括號中的數字比\n指定的數字還小,則\n取下一行的八進制escape作為描述
31 \ooctal 和 \xhex
這里的\ooctal是一個八進制的escape值,而\xhex是一個十六進制的escape值,允許在一個正則表達式中嵌入ASCII碼
1.正則表達式 直接量字符 字符 匹配 \o //NULL字符(\u0000) \t //制表符(\u0009) \n //換行符(\u000A) \v //垂直制表符(\u000B) \f //換頁符(\u000C) \r //回車符(\u000D) \xnn //由十六進制數nn指定的拉丁字符,例如,\x0A等價於\n \uxxxx //由十六進制數nnnn指定的Unicode字符,例如\u0009等價於\t \cX //控制字符^X,例如\cJ等價於換行符\n 2.正則表達式 字符類 字符 匹配 [...] //方括號內的任意字符 [^...] //非方括號內的任意字符 . //除了換行符和其他的Unicode行終止符之外的任意字符 \w //任何ASCII字符組成的單詞,等價於[a-zA-Z0-9] \W //任何非ASCII字符組成的單詞,等價於[^a-zA-Z0-9] \s //任何Unicode空白字符 \S //任何非Unicode空白字符,注意\W和\S的區別 \d //任何ASCII數字,等價於[0-9] \D //任何非ASCII數字,等價於[^0-9] [\b] //退格直接量(特例) 3.正則表達式 重復字符語法 字符 含義 {n,m} //匹配前一項至少n次,最多m次 {n,} //匹配前一項至少n次 {n} //匹配前一項n次 ? //匹配前一項0次或者1次,也就是說前一項是可選的,等價於{0,1} + //匹配前一項至少一次,等價於{1,} * //匹配前一項至少0次,等價於{0,} 4.正則表達式 選擇、分組和引用字符 字符 含義 | //選擇,匹配的是該符號左邊或者右邊的表達式 (...) //組合,將幾項組合合並成一個單元,這個單元可通過"*","+","?"和"|" 等符號組合加以修飾,而且可以記住這個組合相匹配的字符串,用以后面的匹配 (?:...) //只組合,將幾項組合合並成一個單元,但是不記憶,不能用以后面的匹配 \n //和第n個分組第一次匹配的字符相匹配,組是括號里面的表達式 5.正則表達式 錨字符 字符 含義 ^ //匹配字符串的開頭,在多行檢索中,匹配一行的開始 $ //匹配字符串的結尾,在多行檢索中,匹配一行的結尾 \b //匹配單詞的邊界,簡而言之,就是位於字符\w和\W之間,或者位於\W和 //字符串開始或者結尾的位置,但是需要注意,[\b]是退格符 \B //匹配非單詞邊界位置 (?=p) //零寬正向先行斷言,要求接下來的字符都與p匹配,但是不能包括匹配p的那些字符 (?!p) //零寬負向先行斷言,要求接下來的字符不與p匹配 6.正則表達式 修飾符 字符 含義 i //執行不區分大小寫的匹配 g //執行一個全局匹配,簡而言之,找到所有的匹配,而不是找到第一個就停止 m //多行匹配模式,^匹配一行的開始和字符串的開始,$匹配行的結尾和字符串的結尾