javascript - 使用替换字符串的函数替换字符串

标签 javascript regex string

我想找到一个高性能且优雅的解决方案来解决这个问题:

我需要用已替换内容的函数替换字符串的子字符串(不区分大小写)。

示例:

var highlight = function(inputString, filterString) {
    var regex = new RegExp(filterString, 'gi');
    return inputString.replace(regex, '<b>' + filterString + '</b>');
};

highlight('The input', 't');

如果您在浏览器控制台中运行此命令,您将得到:

"<b>t</b>he inpu<b>t</b>"

我的问题是我想保留替换字符串的原始大小写。因此,预期结果是:

"<b>T</b>he inpu<b>t</b>"

有什么想法吗?

编辑:@georg 的回答:

return inputString.replace(regex, '<b>$&</b>');

最佳答案

只需在替换中使用$&,这意味着“已找到的内容”:

var highlight = function(inputString, filterString) {
    var regex = new RegExp(filterString, 'gi');
    return inputString.replace(regex, '<b>$&</b>');
};

x = highlight('The input', 't');
document.write("<pre>" + JSON.stringify(x,0,3));   

其他$...魔术构造,供引用:

enter image description here

MDN

关于javascript - 使用替换字符串的函数替换字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29251503/

相关文章:

javascript - 为什么这个索引签名不能是可选的?

javascript - 了解 Canvas 中的 Javascript 异步 setInterval

regex - SED 删除带有 REGEX 模式的行

javascript - 将社交媒体的外部Javascript加载到网页中的目的

JavaScript - "implementation-defined object"

JavaScript 正则表达式 5-5000

python - 如何使用 Python 识别字符串中千位空格分隔符的数字?

string - 如何定义函数以在 Python 3 中将字符串作为输入

Python - Pandas - 仅删除只有数字的拆分,但如果有字母则保留

java - 带有 StringBuilder 和 CharSequence 的 ClassCastException