正则表达式小括号的多义性
小括号在正则表达式这有以下意义
- 限定量词作用的范围
- 限定多选结构的范围
- 为反向引用捕获文本
- 分组捕获
- 只分组不捕获
- 前瞻
一、限定量词作用的范围
1 2 3 | var reg1 = /(Matz)?/; // 0或1个Matz var reg2 = /(Matz)+/; // 1个以上Matz var reg3 = /(Matz)*/; // 0或多个Matz |
二、限定多选结构的范围
1 2 3 4 | var reg = /(Matz|Eich)/ reg.test( 'Matz' ) // => true reg.test( 'Eich' ) // => true reg.test( 'John' ) // => false |
三、为反向引用捕获文本
1 2 3 4 5 6 | var reg = /(boy)\1/ // 相当于 /boyboy/ reg.test( 'boy' ) // => false reg.test( 'boyboy' ) // => true var reg /(boy)(girl)\1\2/ reg.test( 'boygirlboygirl' ) // => true |
四、分组捕获
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | var reg1 = /(\d{3}) (\d{3})/ var str = '111 222' str.replace(reg1, '$2 $1' ) // => '222 111' , 注意这里的$2,$1,存放了匹配的字符串 var reg2 = /(\d{3})(\d{4})(\d{4})/ var mobile = '13522722724' reg2.test(mobile) RegExp.$1 // => 135 RegExp.$2 // => 2272 RegExp.$3 // => 2724 var reg3 = /(\d{3})(\d{4})(\d{4})/ var mobile = '13522722724' mobile.replace(reg3, '$1 $2 $3' ) // => '135 2272 2724' |
五、只分组不捕获(和 "?:" 一起)
1 2 3 | var reg = /(?:\d+)/ reg.test( '13522722724' ) RegExp.$1 // => '' 不存储匹配的元素 |
较长的正则表达式中,反向引用会降低匹配速度,性能降低,不需要反向引用时应使用分组不捕获。
六、前瞻(lookahead,和 "?=" 一起)
它告诉正则表达式向前看一些字符但不移动位置,前瞻不匹配任何字符只匹配文本中的特定位置。
1 2 3 4 5 | var reg = /(John) (?=Resig)/ reg.test( 'John' ) // => false reg.test( 'John Backus' ) // => false reg.test( 'John Reisg' ) // => true RegExp.$1 // => 'John',注意这里不是 "John Resig" |
如下是一个利用前瞻实现手机号格式化的小函数
1 2 3 4 5 6 7 8 9 | /* * 手机号分隔 * 13522722724 -> 135 2272 2724 */ function separateMobile(num) { var arr = ( '0' + num ).replace(/(\d{4})(?=\d)/g, "$1 " ).split( '' ) arr.shift() return arr.join( '' ) } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端
2011-04-08 事件模块的演变(3)
2011-04-08 事件模块的演变(2)
2011-04-08 事件模块的演变(1)
2011-04-08 attachEvent在IE6/7/8下添加同一个类型事件的多个handler执行倒序
2011-04-08 仅IE6/7/8中添加同一个事件handler多次触发后会执行多次