一、基本概念
正则表达式是一种用来匹配文本的字符串模式,是对字符串执行模式匹配的强大工具。它们可以用于搜索、替换和验证文本。
正则表达式由普通字符和特殊字符(元字符)组成。
元字符列表: . ^ $ * + ? { } [ ] \ | ( )
其中,常用的元字符有:
. : 匹配除换行符外的任意字符。 ^ : 匹配字符串的开头。 $ : 匹配字符串的结尾。 * : 匹配前面的子表达式零次或多次。 + : 匹配前面的子表达式一次或多次。 ?: 匹配前面的子表达式零次或一次。 {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!'结尾