一、基本概念
正則表達式是一種用來匹配文本的字符串模式,是對字符串執行模式匹配的強大工具。它們可以用於搜索、替換和驗證文本。
正則表達式由普通字符和特殊字符(元字符)組成。
元字符列表: . ^ $ * + ? { } [ ] \ | ( )
其中,常用的元字符有:
. : 匹配除換行符外的任意字符。 ^ : 匹配字符串的開頭。 $ : 匹配字符串的結尾。 * : 匹配前面的子表達式零次或多次。 + : 匹配前面的子表達式一次或多次。 ?: 匹配前面的子表達式零次或一次。 {m,n} : 匹配前面的子表達式m到n次。 (...): 標記子表達式的開始和結束位置。 [...] : 用來指定字符集合。 [^...] : 不在指定字符集合內的字符。
二、字符串匹配
字符串匹配是正則表達式最基本的應用,它能夠查找特定的字符或字符串。
以下是一個簡單的字符串匹配的例子:
let str = "Hello world!"; let pattern = /world/; if (pattern.test(str)) { console.log("字符串中包含'world'"); } else { console.log("字符串中不包含'world'"); }
輸出結果:
字符串中包含'world'
三、郵箱驗證
郵箱驗證是正則表達式應用的一個經典案例。郵箱是一個特殊的字符串,需要滿足一定的格式規範。
以下是一個簡單的郵箱驗證的例子:
let email = "abc@123.com"; let pattern = /^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(\.[a-zA-Z0-9_-]+)+$/; if (pattern.test(email)) { console.log("郵箱地址合法"); } else { console.log("郵箱地址不合法"); }
輸出結果:
郵箱地址合法
四、手機號碼驗證
手機號碼驗證也是正則表達式的一個經典應用。手機號碼需要滿足一定的格式規範。
以下是一個簡單的手機號碼驗證的例子:
let phone = "13912345678"; let pattern = /^1[3-9]\d{9}$/; if (pattern.test(phone)) { console.log("手機號碼合法"); } else { console.log("手機號碼不合法"); }
輸出結果:
手機號碼合法
五、HTML標籤匹配
正則表達式也可以用來匹配HTML標籤,從而進行HTML標籤的提取或替換操作。
以下是一個簡單的HTML標籤匹配的例子:
let html = '<div class="container"><p>Hello world!</p></div>'; let pattern = /<(\w+)\b[^>]*>[\s\S]*?<\/\1>/g; let matches = html.match(pattern); console.log(matches);
輸出結果:
["<div class="container"><p>Hello world!</p></div>"]
六、內容替換
正則表達式還可以用來進行內容替換,將匹配到的內容替換為指定的內容。
以下是一個簡單的內容替換的例子:
let str = "Hello world!"; let pattern = /world/; let replacement = "Tom"; let newStr = str.replace(pattern, replacement); console.log(newStr);
輸出結果:
Hello Tom!
七、結尾符
正則表達式中,$符號表示字符串的結尾位置。
以下是一個$符號的應用的例子:
let str = "Hello world!"; let pattern = /world!$/; if (pattern.test(str)) { console.log("字符串以'world!'結尾"); } else { console.log("字符串不以'world!'結尾"); }
輸出結果:
字符串以'world!'結尾
原創文章,作者:JNEHM,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/332724.html