网站首页 > 技术文章 正文
作者:savokiss
转载链接:https://segmentfault.com/a/1190000021145901
1. 概览
在 JavaScript 中,使用 // 即可创建一个正则表达式对象,当然也可以使用 new RegExp()
常用的跟正则相关的方法有 match、test 和 replace。其中 match,replace 都是字符串上的方法, test 是正则对象上的方法。
下面看具体的图示:
2. 匹配单字符
- /reg/ 可以直接匹配具体的字符串 reg。
- /[arzy]/ 中的中括号[] 则代表匹配 arzy 中的任意单个字符
- /[f-h]/ 中的中杠 - 代表匹配字母表顺序中 f 到 h 中的任意单个字符
- /[1-3]/ 则代表匹配数字 1 到 3
3. 正则选项
正则对象的后面也可以跟选项,JavaScript 中常用的选项有:
- i - 代表忽略大小写
- m - 代表多行匹配
- g - 代表全局匹配(可以匹配多次)
4. 边界匹配
- ^ - 代表匹配字符串的开头
- $ - 代表匹配字符串的结尾
5. 字符匹配
- . - 可以匹配除了换行符外的任意字符
- \d - 可以匹配任意数字
- \D - 可以匹配任意非数字
- \s - 匹配任意空白字符
- \S - 匹配任意非空白字符
- \n - 匹配换行
- \w - 它其实就等同于 [A-Za-z0-9_],即匹配字母数字下划线
6. 量词匹配
- * - 匹配 0 次或多次
- + - 匹配 1 次或多次
- ? - 匹配 0 次或 1 次
- {3} - 匹配 3 次
- {2,4} - 匹配 2、3 或 4 次
- {2,} - 匹配 2 次或多次
7. 分组
() 小括号在正则中代表分组,一般在 match 方法中用来返回全匹配加上多个分组结果,如果使用了 g 选项,则只返回全匹配。
在小括号中你可以使用管道符号 |,它代表或
8. 特殊字符
匹配特殊符号的时候需要加反斜杠 \
JS 中的特殊字符有 ^ $ \ . * + ? () [] {} |
所以如果你需要匹配星号 *,就需要这样写:
\*
9. 取非匹配
匹配除了某个字符的任意字符,需要在中括号[] 中使用 ^
至此 ^ 具有两个含义:
- 如果用于正则表达式的开头,代表匹配字符串的开头
- 如果用于中括号 [] 内部,则代表匹配非此字符
10. 完
上面只是介绍了正则表达式中的基本用法,在日常开发中基本就够用了。更深入的用法比如 贪婪和懒惰、零宽断言 和 捕获 ,感兴趣的小伙伴可以自行学习~
正则很强大,但是也不能滥用。如果你写出了一个很复杂的只有你能看懂的正则,更好的做法是不使用正则去实现它~
最后如果文章和笔记能带您一丝帮助或者启发,请不要吝啬你的赞和收藏,你的肯定是我前进的最大动力
- 上一篇: 前端文件数据格式那些事儿
- 下一篇: 前端常用终端各种命令
猜你喜欢
- 2025-05-23 浅谈3种css技巧——两端对齐
- 2025-05-23 JSONP安全攻防技术
- 2025-05-23 html5学得好不好,看掌握多少标签
- 2025-05-23 Chrome 调试时行号错乱
- 2025-05-23 本文帮你在Unix上玩转C语言
- 2025-05-23 Go 中的安全编码 - 输入验证
- 2025-05-23 31个必备的python字符串方法,建议收藏
- 2024-09-22 正则表达式,这篇看完就够了
- 2024-09-22 web前端布局HTML+CSS
- 2024-09-22 前端网页web开发大神总结的HTML标签-表单元素
你 发表评论:
欢迎- 05-24网络信息安全之敏感信息在传输、显示时如何加密和脱敏处理
- 05-24常见加密方式及Python实现
- 05-24pdf怎么加密
- 05-24aes256 加密 解密 (python3) 「二」
- 05-24深入理解Python3密码学:详解PyCrypto库加密、解密与数字签名
- 05-24Springboot实现对配置文件中的明文密码加密
- 05-24JavaScript常规加密技术
- 05-24信息安全人人平等 谷歌推出低性能安卓手机加密技术
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)