2019-11-06

写了个对应的正则代码,发现自己不会处理正则表达式中的变量,通过度娘查找一番才发现解决办法。


    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 );

    }

正则表达式十分强大,学好它能使我们事半功倍。

正则表达式30分钟入门教程

一、字面量

其实当我们定义一个字符串,一个数组,一个对象等等的时候,我们习惯用字面量来定义,例如:

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

来源:简书

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容