1. 概覽
在 JavaScript
中,使用 //
即可創建一個正則表達式對象,當然也可以使用 new RegExp()
常用的跟正則相關的方法有 match
、test
和 replace
。
其中 match
,replace
都是字符串上的方法, test
是正則對象上的方法。
下面看具體的圖示:
2. 匹配單字符
-
/reg/
可以直接匹配具體的字符串reg
。 -
/[arzy]/
中的中括號[]
則代表匹配arzy
中的任意單個字符 -
/[f-h]/
中的中槓-
代表匹配字母表順序中f
到h
中的任意單個字符 -
/[1-3]/
則代表匹配數字 1 到 3
3. 正則選項
正則對象的後面也可以跟選項,JavaScript
中常用的選項有:
-
i
- 代表忽略大小寫 -
m
- 代表多行匹配 -
g
- 代表全局匹配(可以匹配多次)
4. 邊界匹配
-
^
- 代表匹配字符串的開頭 -
$
- 代表匹配字符串的結尾
5. 字符匹配
-
.
- 可以匹配除了換行符外的任意字符 -
\d
- 可以匹配任意數字 -
\D
- 可以匹配任意非數字 -
\s
- 匹配任意空白字符 -
\S
- 匹配任意非空白字符 -
\n
- 匹配換行 -
\w
- 它其實就等同於[A-Za-z0-9_]
,即匹配字母數字下劃線
6. 量詞匹配
-
*
- 匹配 0 次或多次 -
+
- 匹配 1 次或多次 -
?
- 匹配 0 次或 1 次 -
{3}
- 匹配 3 次 -
{2,4}
- 匹配 2、3 或 4 次 -
{2,}
- 匹配 2 次或多次
7. 分組
()
小括號在正則中代表分組,一般在 match
方法中用來返回全匹配加上多個分組結果,如果使用了 g
選項,則只返回全匹配。
在小括號中你可以使用管道符號 |
,它代表或
8. 特殊字符
匹配特殊符號的時候需要加反斜槓 \
JS 中的特殊字符有 ^ $ \ . * + ? () [] {} |
所以如果你需要匹配星號 *
,就需要這樣寫:\*
9. 取非匹配
匹配除了某個字符的任意字符,需要在中括號[]
中使用 ^
至此 ^具有兩個含義:
-
如果用於正則表達式的開頭,代表匹配字符串的開頭
-
如果用於中括號
[]
內部,則代表匹配非此字符
[ ]:
用多種可能性匹配單個字符
//匹配 "cat" "fat" and "mat" 但不匹配 "bat"
const regexWithCharClass = /[cfm]at/g;
const testString = "cat fat bat mat";
const allMatchingWords = testString.match(regexWithCharClass);// ["cat", "fat", "mat"]
匹配字母表中的字母:使用字符集內的範圍 [a-z]
^:
限定開頭
/^a.*/ : 匹配的是一個位置, 而不是具體的某個字符,匹配以小寫的「a」開頭的字符串, 如「alibaba」,但不能匹配「baidu」
取反
/^[^ab].*/ : 匹配除「a」和「b」以外的所有字符串開頭的字符串;不匹配「a」和「b」開頭的字符串
常用表達式:
手機號:/^1((3[\d])|(4[5,6,9])|(5[0-3,5-9])|(6[5-7])|(7[0-8])|(8[1-3,5-8])|(9[1,8,9]))\d{8}$/
大寫字母:/^[A-Z]+$/
日期,如: 2000-01-01:/^\d{4}(-)\d{1,2}\1\d{1,2}$/
email地址 /^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/
國內座機電話,如: 0341-86091234 /\d{3}-\d{8}|\d{4}-\d{7}/
身份證號(15位、18位數字),最後一位是校驗位,可能爲數字或字符X /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/
帳號是否合法(字母開頭,允許5-16字節,允許字母數字下劃線組合 /^[a-zA-Z][a-zA-Z0-9_]{4,15}$/
只包含中文 /^[\u4E00-\u9FA5]/
是否小數 /^\d+\.\d+$/
是否電話格式(手機和座機) /^((0\d{2,3}-\d{7,8})|(1[345789]\d{9}))$/
是否8位純數字 /^[0-9]{8}$/
是否html標籤 /<(.*)>.*<\/\1>|<(.*) \/>/
是否qq號格式正確 /^[1-9]*[1-9][0-9]*$/
是否由數字和字母組成 /^[A-Za-z0-9]+$/
是否小寫字母組成 /^[a-z]+$/
密碼強度正則,最少6位,包括至少1個大寫字母,1個小寫字母,1個數字,1個特殊字符
/^.*(?=.{6,})(?=.*\d)(?=.*[A-Z])(?=.*[a-z])(?=.*[!@#$%^&*? ]).*$/
用戶名正則,4到16位(字母,數字,下劃線,減號) /^[a-zA-Z0-9_-]{4,16}$/
ipv4地址正則 /^(?:(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)\.){3}(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)$/
16進制顏色 /^#?([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/
微信號,6至20位,以字母開頭,字母,數字,減號,下劃線 /^[a-zA-Z]([-_a-zA-Z0-9]{5,19})+$/
中國郵政編碼 /^(0[1-7]|1[0-356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[0-5]|8[013-6])\d{4}$/
只包含中文和數字 /^(([\u4E00-\u9FA5])|(\d))+$/
非字母 /[^A-Za-z]/
手機號隱藏中間4位 "12345678900".reaplace(/(\d{3})\d{4}(\d{4})/,'$1****$2')