ETH*_*ons 7 javascript regex replace
我正在编写一个函数来递归替换字符串中正则表达式的匹配.替换可以是一个函数,就像vanilla一样.replace,此函数可以通过其中一个参数访问原始字符串.
我希望我的函数在每次迭代时只替换一个匹配.对于非全局正则表达式,情况总是如此.但是,此函数接收的一些正则表达式将是全局的.做一个传统.replace(regex, replacement)意味着它可以在每次迭代中多次替换,不仅搞乱处理匹配的顺序,而且还将不正确的索引和原始字符串传递给替换函数.
举个例子:
function recursiveReplace(string, regex, replacement) {
for (var i = 1e8; i > 0 && regex.test(string); i--)
string = string.replace(regex, replacement);
return string;
}
console.log(
recursiveReplace("abcdef", /../g, function (match, index, original) {
console.log(original);
return match[0];
})
);
Run Code Online (Sandbox Code Playgroud)
这输出
abcdef
abcdef
abcdef
ace
ae
a
Run Code Online (Sandbox Code Playgroud)
当所需的输出是
abcdef
acdef
adef
aef
af
a
Run Code Online (Sandbox Code Playgroud)
我怎样才能让函数在每次迭代时只处理一个匹配,无论正则表达式是否有g标志?请注意,我正在以这样的方式使用该函数,即第二个参数将始终是正则表达式(我无法控制它,也无法控制所述正则表达式是否具有该g标志).
看来最好的方法是g从正则表达式中手动删除该标志。这是我能找到的最跨平台的方法,用于regex.toString()获取正则表达式的字符串表示形式:
function recursiveReplace(string, regex, replacement) {
regex = eval(regex.toString().replace(/[a-z]*$/, function (s) {
return s.replace('g', '');
}));
for (var i = 1e8; i > 0 && regex.test(string); i--)
string = string.replace(regex, replacement);
return string;
}
Run Code Online (Sandbox Code Playgroud)
有了 ES6 的特性RegExp(regex),RegExp#flags这变得更加容易:
function recursiveReplace(string, regex, replacement) {
regex = eval(regex.toString().replace(/[a-z]*$/, function (s) {
return s.replace('g', '');
}));
for (var i = 1e8; i > 0 && regex.test(string); i--)
string = string.replace(regex, replacement);
return string;
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
479 次 |
| 最近记录: |