我正在尝试根据预先定义的搜索词列表及其应替换的内容,创建一个替换一组代码中特定字符串的函数,
render = (data,list) => {
let temp = data;
for(let i in list){
temp.split(i).join(list[i]);
//temp.replace(new RegExp(i, 'g'), list[i]); even this doesn't work
}
return temp;
}
let test = render("<h1>a1</h1>",
{ "a1" : "Hello World" });
我没有看到任何错误,它只是不替换任何内容并返回原始数据,如果我单独使用用于替换的代码并手动放置在regExp中的值或拆分连接函数,它工作正常..
//修改
预期的输入和输出应为,
let temp = "<h1> $1 </h1>";
console.log( render(test, { "$1":"Hello World" } ) );
这应该输出,
<h1> Hello World </h1>
但我改为
<h1> $1 </h1>
原样。
答案 0 :(得分:2)
此处的解决方案 -
render = (data, list) => {
let temp = data;
for (let i in list) {
temp = temp.replace(new RegExp(i, 'g'), list[i]);
}
return temp;
}
let test = render("<h1>a1</h1>", {
"a1": "Hello World"
});
console.log(test);
&#13;