正则表达式(Regular Expression)是用于匹配字符串中字符组合的模式。在 JavaScript中,正则表达式也是对象
通常用来查找、替换那些符合正则表达式的文本,许多语言都支持正则表达式。
正则表达式在 JavaScript中的使用场景:
例如验证表单:用户名表单只能输入英文字母、数字或者下划线, 昵称输入框中可以输入中文(匹配)
过滤掉页面内容中的一些敏感词(替换)
从字符串中获取我们想要的特定部分(提取)等 。
(1)定义规则 (2)查找
JavaScript 中定义正则表达式的语法有两种,我们先学习其中比较简单的方法:
定义正则表达式语法:
判断是否有符合规则的字符串:
test() 方法 用来查看正则表达式与指定的字符串是否匹配
语法:
比如:
检索(查找)符合规则的字符串:
exec() 方法 在一个指定字符串中执行一个搜索匹配
语法:
比如:
正则表达式检测查找 test方法和exec方法有什么区别?
test方法 用于判断是否有符合规则的字符串,返回的是布尔值 找到返回true,否则false
exec方法用于检索(查找)符合规则的字符串,找到返回数组,否则为null
普通字符:
元字符(特殊字符)
参考文档:
为了方便记忆和学习,我们对众多的元字符进行了分类:
(1)边界符
正则表达式中的边界符(位置符)用来提示字符所处的位置,主要有两个字符
边界符 | 说明 |
---|---|
^ | 表示匹配行首的文本(以谁开始) |
$ | 表示匹配行尾的文本(以谁结束) |
(2)量词
量词用来 设定某个模式出现的次数
量词 | 说明 |
---|---|
* |
重复零次或更多次 |
+ |
重复一次或更多次 |
? |
重复零次或一次 |
{n} |
重复n次 |
{n,} |
重复n次或更多次 |
{n,m} |
重复n到m次 |
例如:
[]
匹配字符集合
[abc].test('abc')
[]
理解为只能存储1个字符,[abc]
可以理解为abc中的任意一个字符,三选一,可以是a,可以是b,可以是c[]
里面加上 - 连字符
使用连字符 - 表示一个范围
比如:
[a-z]
表示 a 到 z 26个英文字母都可以[a-zA-Z]
表示大小写都可以[0-9]
表示 0~9 的数字都可以认识下:
[]
里面加上 ^ 取反符号
[^a-z]
匹配除了小写字母以外的字符.
匹配除换行符之外的任何单个字符
预定义:指的是某些常见模式的简写方式。
预定类 | 说明 |
---|---|
\d |
匹配0-9之间的任一数字,相当于[0-9] |
\D |
匹配所有0-9以外的字符,相当于[^0-9] |
\w |
匹配任意的字母、数字和下划线,相当于[A-Za-z0-9_] |
\W |
除所有字母、数字和下划线以外的字符,相当于[^A-Za-z0-9_] |
\s |
匹配空格(包括换行符、制表符、空格符等),相当于[\t\r\n\v\f] |
\S |
匹配非空格的字符,相当于[^\t\r\n\v\f] |
修饰符约束正则执行的某些细节行为,如是否区分大小写、是否支持多行匹配等
语法:
i 是单词 ignore 的缩写,正则匹配时字母不区分大小写
例如:
g 是单词 global 的缩写,匹配所有满足正则表达式的结果
替换 replace 替换
语法:
例如:
扩展