[]表示匹配这个里面的任意一个字符;()表示捕获型分组,也就是()里面匹配到的内容会被保存下来,以备后续使用;\1表示第一个捕获型分组的内容,也就是说这个位置上的内容要和第一个捕获型分组的内容一样;?表示前面的内容出现0次或者1次。 所以,[HhMsDm]匹配H或h或M或s或D或m,这个匹配的结果会作为\1的内容,?说明\1出现0次或者1次,所以上面的正则等价于 当?匹配0次的时候,即/([HhMsDm])/g; 当?匹配1次的时候,即/([HhMsDm])\1/g; 在情况1的时候,匹配"H", "h", "M", "s", "D", "m";当情况2的时候,匹配"HH", "hh", "MM", "ss", "DD", "mm";所以这个正则会匹配字符串中情况1和情况2匹配的子串。
[]
表示匹配这个里面的任意一个字符;()
表示捕获型分组,也就是()
里面匹配到的内容会被保存下来,以备后续使用;\1
表示第一个捕获型分组的内容,也就是说这个位置上的内容要和第一个捕获型分组的内容一样;?
表示前面的内容出现0
次或者1
次。所以,
[HhMsDm]
匹配H
或h
或M
或s
或D
或m
,这个匹配的结果会作为\1
的内容,?
说明\1
出现0次或者1次,所以上面的正则等价于当?匹配0次的时候,即
/([HhMsDm])/g
;当?匹配1次的时候,即
/([HhMsDm])\1/g
;在情况1的时候,匹配
"H", "h", "M", "s", "D", "m"
;当情况2的时候,匹配
"HH", "hh", "MM", "ss", "DD", "mm"
;所以这个正则会匹配字符串中情况1和情况2匹配的子串。