寫給前端的正則表達式

1. 概覽

在 JavaScript 中,使用 // 即可創建一個正則表達式對象,當然也可以使用 new RegExp()

常用的跟正則相關的方法有 matchtest 和 replace
其中 matchreplace 都是字符串上的方法, test 是正則對象上的方法。

下面看具體的圖示:

2. 匹配單字符

  1. /reg/ 可以直接匹配具體的字符串 reg

  2. /[arzy]/ 中的中括號[] 則代表匹配 arzy 中的任意單個字符

  3. /[f-h]/ 中的中槓 - 代表匹配字母表順序中 f 到 h 中的任意單個字符

  4. /[1-3]/ 則代表匹配數字 1 到 3

3. 正則選項

正則對象的後面也可以跟選項,JavaScript 中常用的選項有:

  1. i - 代表忽略大小寫

  2. m - 代表多行匹配

  3. g - 代表全局匹配(可以匹配多次)

4. 邊界匹配

  1. ^ - 代表匹配字符串的開頭

  2. $ - 代表匹配字符串的結尾

5. 字符匹配

  1. . - 可以匹配除了換行符外的任意字符

  2. \d - 可以匹配任意數字

  3. \D - 可以匹配任意數字

  4. \s - 匹配任意空白字符

  5. \S - 匹配任意空白字符

  6. \n - 匹配換行

  7. \w - 它其實就等同於 [A-Za-z0-9_],即匹配字母數字下劃線

6. 量詞匹配

  1. * - 匹配 0 次或多次

  2. + - 匹配 1 次或多次

  3. ? - 匹配 0 次或 1 次

  4. {3} - 匹配 3 次

  5. {2,4} - 匹配 2、3 或 4 次

  6. {2,} - 匹配 2 次或多次

7. 分組

() 小括號在正則中代表分組,一般在 match 方法中用來返回全匹配加上多個分組結果,如果使用了 g 選項,則只返回全匹配。

在小括號中你可以使用管道符號 |,它代表

8. 特殊字符

匹配特殊符號的時候需要加反斜槓 \

JS 中的特殊字符有 ^ $ \ . * + ? () [] {} |

所以如果你需要匹配星號 *,就需要這樣寫:\*

9. 取非匹配

匹配除了某個字符的任意字符,需要在中括號[] 中使用 ^

至此 ^具有兩個含義:

  1. 如果用於正則表達式的開頭,代表匹配字符串的開頭

  2. 如果用於中括號 [] 內部,則代表匹配非此字符


[ ]:

用多種可能性匹配單個字符

//匹配 "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')


https://mp.weixin.qq.com/s/OQo5pgrsOfMk4Vy-C75EYA

https://mp.weixin.qq.com/s/U1dP7effxMZvLGRa8g5Lrg

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章