如何使用带有变量的正则表达式而不是字符串?

时间:2013-09-04 13:13:02

标签: javascript regex string variables

问过几次,但我无法让它发挥作用。

我在替换各种类名的脚本中做了很多这些。

label.className.replace(/(?:^|\s)ui-icon-checkbox-on(?!\S)/g , ' ui-icon-globe');

并希望用通用函数替换我的replace调用,该函数传递像ui-icon-checkbox-on这样的字符串并返回一个正则表达式对象来处理我的替换。

然而,这不起作用=它没有取代任何东西:

var foo = function (className) {
  return new RegExp("(?:^|\s)" + className + "(?!\S)", "g");
};

label.className = label.className.replace(foo("ui-icon-checkbox-on"), ' ui-icon-globe');

我不知道为什么会这样理解。

问题
如何正确创建一个正则表达式对象,并用它来用另一个字符串替换字符串?

谢谢!

PS:不,我不想使用jQuery来执行此操作: - )

2 个答案:

答案 0 :(得分:2)

您需要转义转义的RegExp序列:

var foo2 = function (className) {
  return new RegExp("(?:^|\\s)" + className + "(?!\\S)", "g");
  //----------------------^^^---------------------^^^
};

您的原始功能将返回:

foo("ASD")
// returns:
/(?:^|s)ASD(?!S)/g

但我们在此之后:

foo2("ASD")
// returns:
/(?:^|\s)ASD(?!\S)/g

答案 1 :(得分:0)

简单:

var rx = /[W].*/;
var text = "Hello World"
text.replace( rx, "$1" );