今天碰到一个对于我来说奇怪的问题,不知从何查起。在看源代码之前,先来这里问问。不多说,直接上代码。
// 注意这里的a,开头是很多很多很多的空白字符
var a = " 故障原因:测绘一下啊<br>故障进展:"
console.time('compile')
var r = new RegExp('^\s*(?:<(p|p)(?:\s+[^>]*?)?>)?\s*(<span(?:\s+[^>]*?)?>\s*<\/span>|<br(?:\s+[^>]*?)?>| )*\s*(?:<\/\1>)?\s*$', 'i')
// a = '<span><br></span>'
var b = a.replace(r, "")
console.timeEnd('compile')
console.log(b)
console.time('test2')
var c = a.replace(/^\s*(?:<(p|p)(?:\s+[^>]*?)?>)?\s*(<span(?:\s+[^>]*?)?>\s*<\/span>|<br(?:\s+[^>]*?)?>| )*\s*(?:<\/\1>)?\s*$/i,"")
console.timeEnd('test2')
console.log(c)
这个运行结果如下:
疑惑的地方是new RegExp
这个做了什么,让正则运行效率这么高,跟使用.compile
效果差不多(隐含会编译?)。还有就是直接使用正则来replace
速度就慢很多,是因为没有编译的缘故吗?有什么好的文档可以看看?
望各位大大指点:)
迷茫2017-04-10 16:04:28
我也是个新手,我说说看自己的看法吧。
上面的那个r储存了一个正则对象,然后b使用replace的时候之所以会快不就是因为匹配规则早已被储存在r中了嘛~
而下面的c则是直接使用了正则,所以就慢咯,所以你的想法是对的。
反正我写正则一般就是习惯先把正则储存在一个变量中,然后再写下面的东西。
其实不仅是正则,无论什么东西,先存在一个自己命名的变量里,这样要用的时候方便快捷,计算机也省心,尤其是遇到要复用的东西,这点更加重要了。