什么是正则表达式以及如何在javascript中应用它?【教程】
技术百科
夜晨
发布时间:2026-01-28
浏览: 次 正则表达式是JavaScript中处理字符串的基础设施,用于搜索、替换、提取和验证;它是由特殊字符组成的模式,描述字符串结构,需配合match()、replace()、test()等方法使用。
正则表达式不是“高级技巧”,而是 JavaScript 中处理字符串的基础设施——只要你要做搜索、替换、提取或验证(比如邮箱、手机号、URL),它就绕不开。
正则表达式到底是什么?
它是一套用特殊字符组合成的“模式”,用来描述字符串的结构。比如 /\d{3}-\d{4}/ 就表示“三位数字 + 一个短横线 + 四位数字”,能匹配 "123-4567",但不匹配 "12-34567"。
关键点:正则本身不执行操作,它只是“告诉 JS 你想要什么样的字符串”。真正干活的是 String.prototype.match()、String.prototype.replace()、RegExp.test() 这些方法。
JavaScript 中创建正则的两种方式

立即学习“Java免费学习笔记(深入)”;
/\b\w+@\w+\.\w+\b/gi
构造函数写法适合动态生成(比如从用户输入拼接):
new RegExp(`\\b\\w+@\\w+\\.${domain}\\b`, 'gi')
注意:构造函数中反斜杠要双写,因为字符串先解析一次转义;而字面量里只被正则引擎解析一次。
- 字面量不能拼变量,
/hello ${name}/是语法错误 - 全局标志
g决定是否找全部匹配,不加就只找第一个 - 忽略大小写用
i,多行匹配用m,粘性匹配用y(较少用)
最常踩的坑:test() 方法的 lastIndex 陷阱
带 g 或 y 标志的正则对象是“有状态”的。连续调用 test() 可能返回不同结果:
const r = /a/g;
r.test('ab'); // true
r.test('ab'); // false —— 因为 lastIndex 已移到位置 1,下次从那里开始找
这在循环中验证多个字符串时极易出错。解决办法:
- 去掉
g标志(如果只关心“是否匹配”,不需要全局) - 每次调用前手动重置:
r.lastIndex = 0 - 改用
String.prototype.search()或RegExp.prototype.exec()配合循环逻辑
实用场景:提取、替换、校验三件套
提取邮箱:
'Contact me at user@example.com'.match(/\b\w+@\w+\.\w+\b/g)
// → ['user@example.com']
替换所有连续空白为单个空格:
'a\t\n b'.replace(/\s+/g, ' ')
// → 'a b'
校验密码强度(至少 8 位,含大小写字母和数字):
/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d).{8,}$/.test('Abc12345')
// → true
注意:密码校验别只靠前端正则,后端必须重复验证;而且真实项目中建议用专门的密码策略库,而不是硬写复杂正则。
正则写得越长,越容易漏掉边界情况(比如邮箱里允许 + 和 .,但不能开头或结尾)。与其死磕一个“完美”正则,不如分步校验:先格式,再查域名是否存在,最后看 SMTP 响应。
# ai
# 后端
# js
# 循环
# javascript
# java
# String
# 构造函数
# 字符串
# 前端
# 邮箱
# 正则表达式
相关栏目:
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
AI推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
SEO优化<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
技术百科<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
谷歌推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
百度推广<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
网络营销<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
案例网站<?muma echo $count; ?>
】
<?muma
$count = M('archives')->where(['typeid'=>$field['id']])->count();
?>
【
精选文章<?muma echo $count; ?>
】
相关推荐
- Win10怎样卸载DockerDesktop_Wi
- php怎么操作Redis_Redis扩展连接与基本
- Windows执行文件被SmartScreen拦截
- Windows 11登录时提示“用户配置文件服务登
- VSC怎样用终端运行PHP_命令行执行脚本的步骤【
- mac本地php环境如何开启curl_curl扩展
- Win11怎么关闭任务栏小图标_Windows11
- 如何优化Golang Web性能_Golang H
- c++ try_emplace用法_c++ map
- Win11怎么连接蓝牙耳机_Win11蓝牙设备配对
- Win11怎么设置触控板手势_Windows11三
- Python代码测试策略_质量保障解析【教程】
- c++中的CRTP是什么 c++奇异递归模板模式【
- MAC怎么设置程序窗口永远最前_MAC窗口置顶插件
- Python实现图数据库操作_Neo4j核心CRU
- 如何使用Golang sync.Map实现并发安全
- Win11怎么关闭搜索历史_Win11清除设备上的
- Mac怎么查看活动监视器_理解Mac进程和资源占用
- Windows10如何更改任务栏高度_Win10解
- Win11如何连接Xbox手柄 Win11蓝牙连接
- Mac怎么安装软件_Mac安装dmg与pkg文件的
- mac怎么安装pip_MAC Python pip
- Win11怎么更改输入法顺序_Win11调整语言首
- 如何使用 Selenium 正确获取篮球参考网站球
- PHP主流架构如何处理会话管理_Session与C
- Win11怎么开启移动热点_Windows11共享
- PHP接收参数值为空怎么办_判断和处理空参数方法说
- Win11如何设置开机问候语 Win11修改登录界
- windows如何备份注册表_windows导出和
- Win11怎么解压RAR文件 Win11自带解压功
- Win11怎么自动隐藏任务栏_Win11全屏显示设
- PowerShell怎么创建复杂的XML结构
- Python对象比较排序规则_集合使用说明【指导】
- 如何在 Go 中高效缓存与分发网络视频流
- 如何在 IIS 上为 ASP.NET 6 应用排除
- Windows10如何更改开机密码_Win10登录
- Windows 10怎么录屏_Windows 10
- Win11怎么设置按流量计费_Win11限制后台流
- Windows系统文件被保护机制阻止怎么办_权限不
- 如何在Golang中实现微服务服务拆分_Golan
- VSC怎么快速定位PHP错误行_错误追踪设置法【方
- Python大型项目拆分策略_模块化解析【教程】
- Win11如何关闭小娜Cortana Win11禁
- php修改数据怎么改富文本_update更新htm
- Win10怎么查看内存时序参数_Win10CPU-
- Win11如何卸载OneDrive_Win11卸载
- Win11讲述人怎么关闭_Win11误触开启语音朗
- 如何在Golang中写入XML文件_生成符合规范的
- Windows10如何重置此电脑_Windows1
- 如何在Golang中使用container/hea

QQ客服