最近看 php 的文档发现很多看不懂的正则,原来之前只是会了基础,这次来总结下几个特殊的正则模式。js 正则表达式基础可参考正则表达式总结。
这两个比较常用,表示懒惰匹配,即匹配符合条件的尽量短的字符串。默认情况下 + 和 * 是贪婪匹配,即匹配尽可能长的字符串,在它们后面加上 ? 表示想要进行懒惰匹配。
表示一个过滤条件,若字符串符合 pattern 则将其过滤掉。在分析日志时很有用,例如想过滤掉包含 info 标记的日志可以写 ^(?!.*info).*$。
这条规则主要是为了优化性能,对匹配没有影响。它表示括号内的子表达式匹配的结果不需要返回也不会被 $1 $2 之类的反向引用。
<script>
var str3 = "haaaaaaaaaaaaaaaabaaaaaaaaaaaab";
console.log(str3.match(/h.*b/));
console.log(str3.match(/h.*?b/));
console.log(str3.match(/ha+/));
console.log(str3.match(/ha+?/));
var str = "hello123back, hello456back";
console.log(str.match(/hello(?!456).*?back/));
console.log((str.match(/(hello).*/)));
console.log((str.match(/(?:hello).*/)));
var str2 = '<input type="text" id="xxx" name="xxx" value="xxx" /><input type="hidden" id="xxx" name="xxx" value="xxx" />';
console.log(str2.match(/<input[^>]*?hidden.*?\/>/));
</script>