写了个对应的正则代码,发现自己不会处理正则表达式中的变量,通过度娘查找一番才发现解决办法。
function replaceStr(oldStr, childStr){
var re = new RegExp(childStr, "g");//通过RegExp使用变量
oldStr = oldStr.replace(re, '替换');
console.log(oldStr );
}
通过eval()执行字符串拼接也可以解决
function replaceStr(oldStr, childStr){
oldStr = oldStr.replace(eval('/'+ childStr +'/g'), '替换');
console.log(oldStr );
}
正则表达式十分强大,学好它能使我们事半功倍。
一、字面量
其实当我们定义一个字符串,一个数组,一个对象等等的时候,我们习惯用字面量来定义,例如:
vars="string";vara=[1,2];varo={};
如果需要加入变量,那也是十分简单的事情,比如:
varv="bl";vars="string"+v;//"stringbl"vara=[1,v];//[1,"bl"]varo={first:v};//{first : "bl"}
但是,如果碰到了用正则字面量,貌似一切就没这么好了。
varv="bl";varre=/^\d+$/gim;
这时,假如你想给\d+后面加入v这个变量,你会发现,没法弄。因为无论你怎么写,都会被当作正则的一部分来处理。
二、构造函数法
在JS的世界中。除了null,undefined。其余皆是对象。
不过,这里肯定有人说,string、number、boolean怎么会是对象呢。
其实虽然我上面那句话不准确,但确实是最直观的感受。因为string、number、boolean在你用的时候,会默认的被相应的基本包装类型给转换成对象。
然后我们又知道,在JS中,所有的对象都是通过构造函数来生成的。
那么,我们就可以用构造函数来代替字面量定义法,例如:
var s = new String("string"); //String对象,toString()后为"string"
var a = new Array(1,2); //[1,2]
var o = new Object(); //{}
相应的,我们也可以用构造函数来生成正则表达式
varre=newRegExp("^\\d+$","gim");//注意,反斜杠需要转义那么,给它加变量,就和我们前面写的给字符串加变量一样了。varv="bl";varre=newRegExp("^\\d+"+v+"$","gim");// re为/^\d+bl$/gim
至此,最初的问题问题也完全解决了。
作者:Joe_Somebody
链接:https://www.jianshu.com/p/3ecad04b45a4
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。