JavaScript 之 正则详解(?=、?!、?<=、?<!)、捕获性括号、非捕获性括号

基础介绍

基础介绍就不多赘述了,都是来自菜鸟教程:https://www.runoob.com/jsref/jsref-obj-regexp.html 里面的内容

基础语法

  1. 构造函数

    语法:
    参数1:表达式,且需要注意的是对于一些\w等需要通过反斜杠进行转义
    参数2:修饰符,i g m

    var reg = new RegExp(pattern, modifiers)
    

    示例:

    var reg = new RegExp("\\w+", 'g')
    
  2. 字面量

    语法:

    var reg = /pattern/modifiers
    

    示例:

    var reg = /\w+/
    

修饰符

修饰符用于执行区分大小写和全局匹配:

修饰符描述
i执行对大小写不敏感的匹配。
g执行全局匹配(查找所有匹配而非在找到第一个匹配后停止)。
m执行多行匹配。

方括号

方括号用于查找某个范围内的字符:

表达式描述
[abc]查找方括号之间的任何字符。
[^abc]查找任何不在方括号之间的字符。
[0-9]查找任何从 0 至 9 的数字。
[a-z]查找任何从小写 a 到小写 z 的字符。
[A-Z]查找任何从大写 A 到大写 Z 的字符。
[A-z]查找任何从大写 A 到小写 z 的字符。
[adgk]查找给定集合内的任何字符。
[^adgk]查找给定集合外的任何字符。
(red|blue|green)查找任何指定的选项。

元字符

元字符(Metacharacter)是拥有特殊含义的字符

元字符描述
.查找单个字符,除了换行和行结束符。
\w查找数字、字母及下划线。
\W查找非单词字符。
\d查找数字。
\D查找非数字字符。
\s查找空白字符。
\S查找非空白字符。
\b匹配单词边界。
\B匹配非单词边界。
\0查找 NULL 字符。
\n查找换行符。
\f查找换页符。
\r查找回车符。
\t查找制表符。
\v查找垂直制表符。
\xxx查找以八进制数 xxx 规定的字符。
\xdd查找以十六进制数 dd 规定的字符。
\uxxxx查找以十六进制数 xxxx 规定的 Unicode 字符。

量词

量词描述
n+匹配任何包含至少一个 n 的字符串。例如,/a+/ 匹配 “candy” 中的 “a”,“caaaaaaandy” 中所有的 “a”。
n*匹配任何包含零个或多个 n 的字符串。例如,/bo*/ 匹配 “A ghost booooed” 中的 “boooo”,“A bird warbled” 中的 “b”,但是不匹配 “A goat grunted”。
n?匹配任何包含零个或一个 n 的字符串。例如,/e?le?/ 匹配 “angel” 中的 “el”,“angle” 中的 “le”。
n{X}匹配包含 X 个 n 的序列的字符串。例如,/a{2}/ 不匹配 “candy,” 中的 “a”,但是匹配 “caandy,” 中的两个 “a”,且匹配 “caaandy.” 中的前两个 “a”。
n{X,}X 是一个正整数。前面的模式 n 连续出现至少 X 次时匹配。例如,/a{2,}/ 不匹配 “candy” 中的 “a”,但是匹配 “caandy” 和 “caaaaaaandy.” 中所有的 “a”。
n{X,Y}X 和 Y 为正整数。前面的模式 n 连续出现至少 X 次,至多 Y 次时匹配。例如,/a{1,3}/ 不匹配 “cndy”,匹配 “candy,” 中的 “a”,“caandy,” 中的两个 “a”,匹配 “caaaaaaandy” 中的前面三个 “a”。注意,当匹配 “caaaaaaandy” 时,即使原始字符串拥有更多的 “a”,匹配项也是 “aaa”。
n$匹配任何结尾为 n 的字符串。
^n匹配任何开头为 n 的字符串。
?=n匹配任何其后紧接指定字符串 n 的字符串。
?!n匹配任何其后没有紧接指定字符串 n 的字符串。
贪婪匹配与惰性匹配

贪婪匹配,贪婪,简单理解为就是有多少个我就匹配多少个,尽可能的匹配更多个
惰性匹配,懒惰,简单理解为就是不管有多少个,我就匹配最少最小的那个,其他的懒得匹配了

贪婪匹配

let reg = /\d{2,5}/g
let str = '123 1234 12345 123456'
str.match(reg)

惰性匹配

let reg = /\d{2,5}?/g
let str = '123 1234 12345 123456'
str.match(reg)

在这里插入图片描述

通过对比我们发现,贪婪匹配惰性匹配之间也就是相差了一个?,也就是说在量词符后面加个就是我们说的惰性匹配了

贪婪匹配惰性匹配
n+n+?
n*n*?
n?n??
n{X}n{X}?
n{X,}n{X,}?
n{X,Y}n{X,Y}?

方法

基础方法

方法描述
exec检索字符串中指定的值。返回找到的值,并确定其位置。
test检索字符串中指定的值。返回 true 或 false。
toString返回正则表达式的字符串。

支持正则表达式的 String 对象的方法

方法描述FFIE
search检索与正则表达式相匹配的值。14
match找到一个或多个正则表达式的匹配。14
replace替换与正则表达式匹配的子串。14
split把字符串分割为字符串数组。

位置匹配符

这里将一些模糊点着重说明一下

^

这个大家都很熟悉,匹配开始位置

'aa11..AA22'.replace(/^/, '😜')

在这里插入图片描述

$

这个大家也很熟悉,匹配结束位置

'aa11..AA22'.replace(/$/, '😜')

在这里插入图片描述

\b

匹配边界位置
什么是边界???

就正则而言:边界就是不同的元字符类型或者指定字符的拼接处

可能还是有点不是很好理解,直接用示例说话,相信就容易理解的多了

  • 示例
'aa11..AA22'.replace(/\b/g, '😜')

在这里插入图片描述

  • 示例
'aa11..AA22'.replace(/\b./g, '😜')

说明:.代表的是单个字符,\b.则就表示的是单个字符且处在边界位置的,边界位置在前,单个字符在后
在这里插入图片描述

  • 示例
'aa11..AA22'.replace(/\b../g, '😜')

说明:同理,\b..则就表示的是两个单个字符且处在边界位置的,边界位置在前,两个单个字符在后
在这里插入图片描述

  • 示例
'aa11..AA22'.replace(/..\b/g, '😜')

说明:同理,..\b则就表示的是两个单个字符且处在边界位置的,边界位置在后,两个单个字符在前
在这里插入图片描述

  • 示例
'aa11..AA22'.replace(/\bAA/g, '😜')

在这里插入图片描述

?=

正向先行断言
?=n:匹配任何其后 紧接 指定字符串 n 的字符串,通俗一点说就是匹配字符串 n 前面的那个位置

  • 示例
'aa11..AA22'.replace(/(?=a1)/g, '😜')

说明:?=a1,找到a1字符串所在位置的前面
在这里插入图片描述

?!

负向先行断言
?!n:匹配任何其后 没有紧接 指定字符串 n 的字符串,通俗一点说就是匹配没有字符串 n 前面的那个位置

?= 对比,可以理解为?=n匹配到的位置之外的位置都是属于?!n

  • 示例
'aa11..AA22'.replace(/(?!a1)/g, '😜')

在这里插入图片描述

?<=

?<=n:匹配任何其前 紧接 指定字符串 n 的字符串,通俗一点说就是匹配字符串 n 后面的那个位置

  • 示例
'aa11..AA22'.replace(/(?<=a1)/g, '😜')

在这里插入图片描述

?<!

?<!n:匹配任何其前 没有紧接 指定字符串 n 的字符串,通俗一点说就是匹配没有字符串 n 后面的那个位置

  • 示例
'aa11..AA22'.replace(/(?<!a1)/g, '😜')

在这里插入图片描述

分支符

|

可以理解为 或者的意思,以|为分界线,只要符合|左边或者右边的任意一个字符规则的即为匹配

let reg = /good|nice/g
let str = 'good idea, nice try.' // 都有
console.log(reg.test(str))
// true

let reg = /good|nice/g
let str = 'god idea, nice try.' // 只有其中一个nice
console.log(reg.test(str))
// true

let reg = /good|nice/g
let str = 'god idea, nce try.' // 都没有
console.log(reg.test(str))
// false

在这里插入图片描述

小括号() ------ 另一个说法:子表达式

()的作用可以理解为给括号内的字符形成一个整体,另一个说法说成括号内的为一个子表达式
()可以分成捕获性括号与非捕获性括号,这里说明一下什么是捕获???

捕获:我们用正则()去匹配字符串,一般来说会匹配上对应规则的字符串,另外就还有()对应分组1、分组2、分组3……,同长称之为捕获组,这些个()对应的就是捕获到的字符串的分组字符串。

捕获性括号

(X):匹配X,并捕获匹配项。

非捕获性括号

(?:X):匹配X,但是不捕获匹配项。

在这里插入图片描述

首先,先说明一下: 正则replace
方法:第一个参数代表的是该正则匹配的字符串,倒数第二个参数为匹配的字符串在原字符串中初始出现的索引位置,倒数第一个参数为原字符串,而在它们之间的参数则分别代表的是正则中的分组(也就是圆括号)中所捕获的字符串。
https://www.runoob.com/jsref/jsref-replace.html,最下面的笔记有说明
在这里插入图片描述

也可参考一下我之前写的另一篇博客JavaScript 之 replace() 方法的第二个参数为匿名函数时的理解(涉及正则)
在这里插入图片描述

  • 捕获性括号

案例1

"hello---JavaScript666".replace(/(JavaScript(\d+))/g, "$2")
// 'hello---666'

这种写法可能不那么好理解,那么换成下面那种写法看下

案例2

"hello---JavaScript666".replace(/(JavaScript(\d+))/g,(a, a1, a2, a3) => {
    console.log(a, a1, a2, a3) // JavaScript666 JavaScript666 666 8
})

是不是就好理解了一点,$2对应的就是括号捕获的内容的值,但是$2对应的是第二个括号捕获的值,第一个括号内匹配的字符串还是JavaScript666,因为用的是捕获性括号,所以捕获这个字符串也是JavaScript666,第二个括号(\d+)是捕获性括号,匹配的是数字,捕获的是666

  • 非捕获性括号

案例3

"hello---JavaScript666".replace(/(?:JavaScript(\d+))/g, "$1")
// 'hello---666'

这种写法可能不那么好理解,那么换成下面那种写法看下

案例4

"hello---JavaScript666".replace(/(?:JavaScript(\d+))/g,(a, a1, a2, a3) => {
    console.log(a, a1, a2, a3) // JavaScript666 666 8 hello---JavaScript666
})

是不是就好理解了一点,$1对应的就是括号捕获的内容的值,第一个括号内匹配的字符串还是JavaScript666,因为用了非捕获性括号,所以不捕获这个字符串,第二个括号(\d+)是捕获性括号,匹配的是数字

小结一下:

"hello---JavaScript666".replace(/(?:JavaScript(\d+))/g, "$1"),这种写法的$1,对应的是第一个捕获性括号,$2对应的是第二个捕获性括号,以此类推

  • 3
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 这个 JavaScript 正则表达式的意思是:匹配不在一个负号之后的字符。 其中,?<! 表示负向零宽断言,意思是在匹配的位置的前面不能有负号。 例如,可以用这个正则表达式来匹配自然数,如 0、1、2 等,但不匹配负数,如 -1、-2 等。 示例代码: ``` let regex = /(?<!-)\d+/; let str = "-1 -2 0 1 2 3"; let result = str.match(regex); console.log(result); // ["0", "1", "2", "3"] ``` 上面的代码中,regex 是一个正则表达式,它匹配不在负号之后的数字。然后使用字符串的 match 方法匹配字符串 str,最后将匹配到的结果输出到控制台。输出的结果是 ["0", "1", "2", "3"],表示在字符串 str 中匹配到了 0、1、2、3 这四个数字。 ### 回答2: 这个正则表达式 `(?<!-)` 是一个反向否定预测,用于从给定的字符串中匹配不以连字符(-)开头的部分。 正则表达式的含义解释如下: - `(?<!-)`:表示反向否定预测,即后面不能有连字符(-)。 - 连字符(-):表示匹配连字符(-)字符。 举个例子,假设有字符串 "abc-def-xyz",我们想要匹配不以连字符开头的部分,即 "abc" 和 "xyz"。这个正则表达式 `(?<!-)` 的作用就是匹配不以连字符开头的部分。如果将正则表达式应用于这个字符串,将会匹配到 "abc" 和 "xyz"。 另外,需要注意的是,这个正则表达式只匹配不以连字符开头的部分,而不会移除连字符本身。 总结:这个正则表达式 `(?<!-)` 的意思是匹配不以连字符开头的部分。 ### 回答3: 这个正则表达式中的 `(?<!-)` 意思是负前向断言,用来匹配不以 `-` 符号开头的文本。在正则表达式中,通常我们可以使用 `(?<!...)` 来表示负前向断言,其中 `...` 表示一个具体的模式或者字符。 举个例子,假设我们有一个字符串 `abc-def`,我们希望匹配除了以 `-` 开头的文本之外的所有内容,我们可以使用 `(?<!-)\w+` 来实现。其中 `\w+` 表示匹配一个或多个字母、数字或下划线。 在此例中,正则表达式 `(?<!-)\w+` 会匹配 `abc` 和 `def`,但不会匹配 `-def`。因为 `(?<!-)` 的作用是确保匹配的文本之前不出现 `-` 符号。 这个正则表达式可以在很多情况下使用,例如在对 URL 进行匹配时,我们可以使用 `(?<!-)[a-zA-Z0-9.-]+` 来匹配除了以 `-` 开头的 URL 内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zhuangvi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值