我想将以下正则表达式分成几行代码。
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>';
});
答案 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.