在JavaScript中将长正则表达式分成几行

时间:2015-09-12 08:50:24

标签: javascript regex linewrap

我想将以下正则表达式分成几行代码。

document.body.innerHTML = document.body.innerHTML.replace(/Aarau|Aargau| <break here> more|words|follow|here/g, function(m) {
  return '<span style="background-color:lightblue">'+m+'</span>';
});

1 个答案:

答案 0 :(得分:3)

这是打破界限的简单方法:

document.body.innerHTML = document.body.innerHTML.replace(
    /Aarau|Aargau|more|words|follow|here/g,
    function (m) {
      return '<span style="background-color:lightblue">'+m+'</span>';
    }
);

如果你有一个非常长的正则表达式,把它写成一个字符串并编译它:

var longRegex = new RegExp('Aarau|Aargau|aardvark|aardwolf|' +
    'aargh|more|stuff|earth|worm|earthworm|geese|moose|mice|' +
    'yet|more|and|more|et|cetera|and|so|on', 'g');

document.body.innerHTML = document.body.innerHTML.replace(longRegex,
    function (m) {
      return '<span style="background-color:lightblue">'+m+'</span>';
    }
);

另一种可能性是在数组中编写单个单词,然后在编译正则表达式时将它们与|连接起来。如果您已经存储了一个单词数组,这将非常方便。

var words = ['Aarau', 'Aargau', 'aardvark', 'aardwolf', 'aargh',
    'more', 'stuff', 'earth', 'worm', 'earthworm', 'geese', 'moose', 'mice',
    'yet', 'more', 'and', 'more', 'et', 'cetera', 'and', 'so', 'on'];

var wordRegex = new RegExp(words.join('|'), 'g');
document.body.innerHTML = document.body.innerHTML.replace(wordRegex,
    function (m) {
      return '<span style="background-color:lightblue">'+m+'</span>';
    }
);
There is an aardwolf eating earth containing worms in Aargau.