临摹微笑
[]表示匹配这个里面的任意一个字符;()表示捕获型分组,也就是()里面匹配到的内容会被保存下来,以备后续使用;\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匹配的子串。